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1.0 Introduction to MCS-48™ 

Recent advances in NMOS technology 
have allowed Intel for the first time to place 
enough capability on a single silicon die to 
create a true single-chip microcomputer 
containing all the functions required in a 
digital processing system. A set of such 
microcomputers on single chips, their 
variations, and optional peripherals are 
collectively called the MCS-48 micro- 
computer family. These products are fully 
described in this manual. 

The head of the family is the 8048 
microcomputer which contains the following 
functions in a single 40 pin package: 

8-Bit CPU 

1K x 8 ROM Program Memory 

64 x 8 RAM Data Memory 

27 I/O Lines 

8-Bit Timer/Event Counter 

A 2.5 or 5.0 microsecond cycle time and a 
repertoire of over 90 instructions each 
consisting of either one or two cycles makes 
the single chip 8048the equal in performance 
of most presently available multi-chip NMOS 



microprocessors. The 8048 is, however, a 
true "low-cost" microcomputer. A single 5V 
supply requirement for all MCS-48 com- 
ponents assures that "low cost" also 
applies to the power supply in your system. 

New Family Members 

The MCS-48 family of microcomputers 
which began with the 8048 and 8748 has 
now been expanded with new members 
which provide either more capability or 
lower cost than the original family mem- 
bers. While broadening the applications 
possible with a single chip microcomputer, 
these new microcomputers share both the 
instruction set and development support of 
the 8048. 

The 8049 is a single-chip microcomputer 
which is completely interchangeable with 
the 8048, but contains twice the program 
memory and twice the data memory of the 
8048. The 8035 and 8039 are compatible 
processors without internal program mem- 
ory. The 8039 contains twice the data 
memory of the 8035. 

The 8021 is a new very low cost MCS-48 
family member which contains a subset of 
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the 8048's instruction set and incorporates 
several new features critical in low cost 
applications. 

Even with low component costs; however, a 
project may be jeopardized by high develop- 
ment and rework costs resulting from an 
inflexible production design. Intel has solved 
this problem by creating two pin-compatible 
versions of the 8048 microcomputer: the 
8048 with mask Programmable ROM pro- 
gram memory for low cost production and 
the 8748 with user programmable and 
erasable EPROM program memory for 
prototype development. The 8748 is essen- 
tially a single chip microcomputer "bread- 
board" which can be modified over and over 
again during development and pre-produc- 
tion then replaced by the low cost 8021*, 
8048, or 8049 ROM for volume production. 
The 8748 provides a very easy transition 
from development to production and also 
provides an easy vehiclefortemporaryfield 
updates while new ROMs are being made. 

SPECIAL FEATURES 

SINGLE 5V SUPPLY 

40 PIN DIP OR 28 PIN DIP 

PIN COMPATIBLE ROM AND EPROM 

2.5, 5.0 AND 10.0 M sec CYCLE VERSIONS 

ALL INSTRUCTIONS 1 OR 2 CYCLES 

SINGLE STEP 

8 LEVEL STACK 

2 WORKING REGISTER BANKS 

RC, LC, XTAL, OR EXTERNAL 

FREQUENCY SOURCE 

OPTIONAL CLOCK OUTPUT 

POWER DOWN STANDBY MODE 

To allow the MCS-48 to solve a wide range 
of problems and to provide for future 
expansion, all 8048 and 8049 functions 
have been made externally expandable 
using either special expanders or standard 
memories and peripherals. An efficient low 
cost means of I/O expansion is provided by 
either the 8243 I/O Expander or standard 
TTL or CMOS circuits. The 8243 provides 
16 I/O lines in a 24 pin package. For sys- 
tems with large I/O requirements, multiple 
8243s can be used. 



For such applications as Keyboards, Dis- 
plays, Serial communication lines, etc. 
standard MCS-80/85 peripheral circuits 
may be added. Program and data memory 
may be expanded using standard memories 
or the 8355 and 8155 memories that also 
include programmable I/O lines and timing 
functions. 

For applications which require a more 
custom tailored interface, the 8041 or 8741 
Universal Peripheral Interface (UPI-41) 
devices can be used. The UPI-41 devices 
are available in both ROM and EPROM 
versions and are essentially slave versions 
of the 8048/8748 which are designed to 
interface directly with expandable MCS-48 
processors and provide flexible intelligent 
I/O capability. The 8041/8741 share the 
instruction set of the MCS-48 family of 
processors. 

The 8035 and 8039 are an 8048 or 8049 
respectively without internal program 
memory that allows the user to match his 
program memory requirements exactly by 
using a wide variety of external 
memories. The 8035 and 8039 allow the 
user to select a minimum cost system no 
matter what his program memory re- 
quirements. The 8035L is an 8035 with the 
powerdown mode of the 8048. 

The MCS-48 processors are designed to be 
efficient control processors as well as 
arithmetic processors. They provide an 
instruction set which allows the user to 
directly set and reset individual lines within 
its I/O ports as well as test individual bits 
within the accumulator. A large variety of 
branch and table look-up instructions 
make these processors very efficient in 
implementing standard logic functions. 
Also, special attention has been given to 
code efficiency. Over 70% of the instruc- 
tions are a single byte long and all others 
are only two bytes long. This means many 
functions requiring 1.5K to 2. OK bytes in 
other computers may very well be com- 
pressed into the 1K words resident in the 
8048 or up to 3K to 4K equivalent bytes may 
be compressed into the 8049. 



*The 8021 is code compatible but not pin compatible with the 8748. 
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THE EXPANDED MCS-48™ SYSTEM 



The chart above shows the expansion 
possibilities using the 8048 and 8049 in 
various combinations with the Intel® 8355/ 
8755 Program Memory and I/O Expander 
and the 8155 Data Memory and I/O 
Expander. Data Memory can be expanded 
beyond the resident words in blocks of 256 



by adding 8155's. Program Memory can be 
expanded beyond the resident 1K or 2K in 
blocks of 2K by using the 8355/8755 in com- 
bination with the 8048 or 8049. If all external 
memory is desired, the 8035 or 8039 can be 
substituted for the 8048 and 8049. 
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1.1 The Function of a Computer 

This chapter introduces certain basic com- 
puter concepts. It provides background 
information and definitions which will be 
useful in later chapters of this manual. Those 
already familiar with computers may skip this 
material, at their option. 

1.1.1 A Typical Computer System 

A typical digital computer consists of: 

A central processor unit (CPU) 
Program Memory 
Data Memory 
Input/output (I/O) ports 

The processor memory serves as a place to 
store Instructions, the coded pieces of 
information that direct the activities of the 
CPU, while Memory stores the Data, the 
coded pieces of information that are 
processed by the CPU. A group of logically 
related instructions stored in memory is 
referred to as a Program. The CPU "reads" 
each instruction from memory in a logically 
determined sequence, and uses it to initiate 
processing actions. If the program sequence 
is coherent and logical, processing the 
program will produce intelligible and useful 
results. The program must be organized such 
that the CPU does not read a non-instruction 
word when it expects to see an instruction. 

The CPU can rapidly access any data stored 
in memory; but often the memory is not large 
enough to store the entire data bank required 
for a particular application. The problem can 
be resolved by providing the computer with 
one or more Input Ports. The CPU can 
address these ports and input the data 
contained there. The addition of input ports 
enables the computer to receive information 
from external equipment (such as a paper 
tape reader or floppy disk) at high rates of 
speed and in large volumes. 

A computer also requires one or more Output 
Ports that permit the CPU to communicate 
the result of its processing to the outside 
world. The output may go to a display, for use 
by a human operator, to a peripheral device 
that produces "hard-copy", such as a line- 



printer, to a peripheral storage device, such 
as a floppy disk unit, or the output may 
constitute process control signals that direct 
the operations of another system, such as an 
automated assembly line. Like input ports, 
output ports are addressable. The input and 
output ports together permit the processor to 
communicate with the outside world. 

The CPU unifies the system. It controls the 
functions performed by the other compon- 
ents. The CPU must be able to fetch 
instructions from memory, decode their 
binary contents and execute them. It must 
also be able to reference memory and I/O 
ports as necessary in the execution of 
instructions. In addition, the CPU should be 
able to recognize and respond to certain 
external control signals, such as INTER- 
RUPT requests. The functional units within a 
CPU that enable it to perform these functions 
are described below. 

1.1.2 The Architecture of a CPU 

A typical central processor unit (CPU) 
consists of the following interconnected 
functional units: 

Registers 

Arithmetic/Logic Unit (ALU) 

Control Circuitry 

Registers are temporary storage units within 
the CPU. Some registers, such as the 
program counter and instruction register, 
have dedicated uses. Other registers, such as 
the accumulator, are for more general 
purpose use. 

Accumulator 

The accumulator usually stores one of the 
operands to be manipulated by the ALU. A 
typical instruction might direct the ALU to 
add the contents of some other register to the 
contents of the accumulator and store the 
result in the accumulator itself. In general, 
the accumulator is both a source (operand) 
and a destination (result) register. Often a 
CPU will include a number of additional 
general purpose registers that can be used to 
store operands or intermediate data. The 
availability of general purpose registers 
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eliminates the need to "shuffle" intermediate 
results back and forth between memory and 
the accumulator, thus improving processing 
speed and efficiency. 

Program Counter (Jumps, Subroutines and 
the Stack): 

The instructions that make up a program are 
stored in the system's memory. The central 
processor references the contents of mem- 
ory in order to determine what action is 
appropriate. This means that the processor 
must know which location contains the next 
instruction. 

Each of the locations in memory is 
numbered, to distinguish it from all other 
locations in memory. The number which 
identifies a memory location is called its 
Address. The processor maintains a counter 
which contains the address of the next 
program instruction. This register is called 
the Program Counter. The processor up- 
dates the program counter by adding "1" to 
the counter each time it fetches an 
instruction, so that the program counter is 
always current (pointing to the next instruc- 
tion). 

The programmer therefore stores his instruc- 
tions in numerically adjacent addresses, so 
that the lower addresses contain the first 
instructions to be executed and the higher 
addresses contain later instructions. The 
only time the programmer may violate this 
sequential rule is when an instruction in one 
section of memory is a Jump instruction to 
another section of memory. 

A jump instruction contains the address of 
the instruction which is to follow it. The next 
instruction may be stored in any memory 
location, as long as the programmed jump 
specifies the correct address. During the 
execution of a jump instruction, the proces- 
sor replaces the contents of its program 
counter with the address embodied in the 
Jump. Thus, the logical continuity of the 
program is maintained. 

A special kind of program jump occurs when 
the stored program "Calls" a subroutine. In 



this kind of jump, the processor is required to 
"remember" the contents of the program 
counter at the time that the jump occurs. This 
enables the processor to resume execution 
of the main program when it is finished with 
the last instruction of the subroutine. 

A Subroutine is a program within a program. 
Usually it is a general-purpose set of 
instructions that must be executed repeat- 
edly in the course of a main program. 
Routines which calculate the square, the 
sine, or the logarithm of a program variable 
are good examples of functions often written 
as subroutines. Other examples might be 
programs designed for inputting data to a 
particular peripheral device. 

The processor has a special way of handling 
subroutines, in order to insure an orderly 
return to the main program. When the 
processor receives a Call instruction, it 
increments the Program Counter and stores 
the counter's contents in a reserved memory 
area known as the Stack. The Stack thus 
saves the address of the instruction to be 
executed after the subroutine is completed. 
Then the processor loads the address 
specified in the Call into its Program Counter. 
The next instruction fetched will therefore be 
the first step of the subroutine. 

The last instruction in any subroutine is a 
Return. Such an instruction need specify no 
address. When the processor fetches a 
Return instruction, it simply replaces the 
current contents of the Program Counter 
with the address on the top of the stack. This 
causes the processor to resume execution of 
the calling program at the point immediately 
following the original Call instruction. 

Subroutines are often Nested; that is, one 
subroutine will sometimes call a second 
subroutine. The second may call a third, and 
so on. This is perfectly acceptable, as long as 
the processor has enough capacity to store 
the necessary return addresses, and the 
logical provision for doing so. In other words, 
the maximum depth of nesting is determined 
by the depth of the stack itself. If the stack has 
space for storing three return addresses, then 
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three levels of subroutines may be ac- 
commodated. 

Instruction Register and Decoder 

Every computer has a Word Length that is 
characteristic of that machine. A computer's 
word length is usually determined by the size 
of its internal storage elements and intercon- 
necting paths (referred to as Buses); for 
example, a computer whose registers and 
buses can store and transfer 8-bits of 
information has a characteristic word length 
of 8-bits and is referred to as an 8-bit parallel 
processor. An 8-bit parallel processor gener- 
ally finds it most efficient to deal with 8-bit 
binary fields, and the memory associated 
with such a processor is therefore organized 
to store 8-bits in each addressable memory 
location. Data and instructions are stored in 
memory as 8-bit binary numbers, or as 
numbers that are integral multiples of 8-bits: 
16-bits, 24-bits, and so on. This characteristic 
8-bit field is often referred to as a Byte. If 
however, efficient handling of 4 or even 1-bit 
data is necessary special processor instruc- 
tions can provide this capability. 

Each operation that the processor can 
perform is identified by a unique byte of data 
known as an Instruction Code or Operation 
Code. An 8-bit word used as an instruction 
code can distinguish between 256 alternative 
actions, more than adequate for most 
processors. 

The processor fetches an instruction in two 
distinct operations. First, the processor 
transmits the address in its Program Counter 
to the program memory. Then the program 
memory returns the addressed byte to the 
processor. The CPU stores this instruction 
byte in a register known as the Instruction 
Register, and uses it to direct activities during 
the remainder of the instruction execution. 

The 8-bits stored in the instruction register 
can be decoded and used to selectively 
activate one of a number of output lines. Each 
line represents a set of activities associated 
with execution of a particular instruction 
code. The enabled line can be combined with 
selected timing pulses, to develop electrical 



signals that can then be used to initiate 
specific actions. This translation of code into 
action is performed by the Instruction 
Decoder and by the associated control 
circuitry. 

An 8-bit instruction code is often sufficient to 
specify a particular processing action. There 
are times, however, when execution of the 
instruction requires more information than 8- 
bits can convey. 

One example of this is when the instruction 
references a memory location. The basic 
instruction code identifies the operation to be 
performed, but cannot specify the object 
address as well. In a case like this, a two byte 
instruction must be used. Successive instruc- 
tion bytes are stored in sequentially adjacent 
memory locations, and the processor per- 
forms two fetches in succession to obtain the 
full instruction. The first byte retrieved from 
memory is placed in the processor's instruc- 
tion register, and subsequent byte is placed 
in temporary storage; the processor then 
proceeds with the execution phase. 

Address Register(s) 

A CPU may use a register to hold the address 
of a memory location that is to be accessed 
for data. If the address register is Program- 
mable, (i.e., if there are instructions that allow 
the programmer to alter the contents of the 
register) the program can "build" an address 
in the address register prior to executing a 
Memory Reference instruction (i.e., an 
instruction that reads data from memory, 
writes data to memory or operates on data 
stored in memory). 

Arithmetic/Logic Unit (ALU) 

All processors contain an arithmetic/logic 
unit, which is often referred to simply as the 
ALU. The ALU, as its name implies, is that 
portion of the CPU hardware which performs 
the arithmetic and logical operations on the 
binary data. 

The ALU must contain an Adder which is 
capable of combining the contents of two 
registers in accordance with the logic of 
binary arithmetic. This provision permits the 
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processor to perform arithmetic manipu- 
lations on the data it obtains from memory 
and from its other inputs. 

Using only the basic adder a capable 
programmer can write routines which will 
subtract, multiply and divide, giving the 
machine complete arithmetic capabilities. 
In practice, however, most ALUs provide 
other built-in functions, including boolean 
logic operations, and shift capabilities. 

The ALU contains Flag Bits which specify 
certain conditions that arise in the course of 
arithmetic and logical manipulations. It is 
possible to program jumps which are 
conditionally dependent on the status of one 
or more flags. Thus, for example, the 
program may be designed to jump to a 
special routine if the carry bit is set following 
an additional instruction. 

Control Circuitry 

The control circuitry is the primary functional 
unit within a CPU. Using clock inputs, the 
control circuitry maintains the proper se- 
quence of events required for any processing 
task. After an instruction is fetched and 
decoded, the control circuitry issues the 
appropriate signals (to units both internal 
and external to the CPU) for initiating the 
proper processing action. Often the control 
circuitry will be capable of responding to 
external signals, such as an interrupt. An 
Interrupt request will cause the control 
circuitry to temporarily interrupt main pro- 
gram execution, jump to a special routine to 
service the interrupting device, then auto- 
matically return to the main program. 

1.1.3 Computer Operations 

There are certain operations that are basic to 
almost any computer. A sound understand- 
ing of these basic operations is a necessary 
prerequisite to examining the specific 
operations of a particular computer. 

Timing 

The activities of the central processor are 
cyclical. The processor fetches an instruc- 
tion, performs the operations required, 



fetches the next instruction, and so on. This 
orderly sequence of events requires precise 
timing, and the CPU therefore requires afree 
running oscillator clock which furnishes the 
reference for all processor actions. The 
combined fetch and execution of a single 
instruction is referred to as an Instruction 
Cycle. The portion of a cycle identified with a 
clearly defined activity is called a State. And 
the interval between pulses of the timing 
oscillator is referred to as a Clock Period. As 
a general rule, one or more clock periods are 
necessary for the completion of a state, and 
there are several states in a cycle. 

Instruction Fetch 

The first state(s) of any instruction cycle will 
be dedicated to fetching the next instruction. 
The CPU issues a read signal and the 
contents of the program counter are sent to 
program memory, which responds by 
returning the next instruction word. The first 
byte of the instruction is placed in the 
instruction register. If the instruction con- 
sists of more than one byte, additional states 
are required to fetch the second byte of the 
instruction. When the entire instruction is 
present in the CPU, the program counter is 
incremented (in preparation for the next 
instruction fetch) and the instruction is 
decoded. The operation specified in the 
instruction will be executed in the remaining 
states of the instruction cycle. The instruc- 
tion may call for a data memory read or write, 
an input or output and/or an internal CPU 
operation, such as a register-to-register 
transfer or an add operation. 

Memory Read 

An instruction fetch is merely a special 
program memory read operation that brings 
the instruction to the CPU's instruction 
register. The instruction fetched may then 
call for data to be read from data memory 
into the CPU. The CPU again issues a read 
signal and sends the proper memory 
address; memory responds by returning the 
requested word. The data received is placed 
in the accumulator or one of the other 
general purpose registers (not the instruc- 
tion register). 
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Memory Write 

A memory write operation is similar to a read 
except for the direction of data flow. The 
CPU issues a write signal, sends the proper 
memory address, then sends the data word 
to be written into the addressed data memory 
location. 

Input/Output 

Input and Output operations are similar to 
memory read and write operations with the 
exception that an I/O port is addressed 
instead of a memory location. The CPU 
issues the appropriate input or output 
control signal, sends the proper address and 
either receives the data being input or sends 
the data to be output. 

Data can be input/output in either parallel or 
serial form. All data within a digital computer 
is represented in binary coded form. A binary 
data word consists of a group of bits; each bit 
is either a one or a zero. Parallel I/O consists 
of transferring all bits in the word at the same 
time, one bit per line. Serial I/O consists of 
transferring one bit at a time on a single line. 
Naturally serial I/O is much slower, but it 
requires considerable less hardware than 
does parallel I/O. 

Interrupts 

Interrupt provisions are included on many 
central processors, as a means of improving 



the processor's efficiency. Consider the case 
of a computer that is processing a large 
volume of data, portions of which are to be 
output to a printer. The CPU can output a 
byte of data within a single machine cycle but 
it may take the printer the equivalent of many 
machine cycles to actually print the char- 
acter specified by the data byte. The CPU 
could then remain idle waiting until the 
printer can accept the next data byte. If an 
interrupt capability is implemented on the 
computer, the CPU can output a data byte 
then return to data processing. When the 
printer is ready to accept the next data byte, it 
can request an interrupt. When the CPU 
acknowledges the interrupt, it suspends 
main program execution and automatically 
branches to a routine that will output the next 
data byte. After the byte is output, the CPU 
continues with main program execution. 
Note that this is, in principle, quite similar to a 
subroutine call, except that the jump is 
initiated externally rather than by the 
program. 

More complex interrupt structures are 
possible, in which several interrupting 
devices share the same processor but have 
different priority levels. Interruptive proces- 
sing is an important feature that enables 
maximum utilization of a processor's capa- 
city for high system throughput. 
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1.2 Programming a Microcomputer 
1.2.1 Machine Language Programming 

A microprocessor is instructed what to do by 
programming it with a series of instructions 
stored in Program Memory. The processor 
fetches these instructions one at a time and 
performs the operation indicated. These 
instructions must be stored in a form that the 
processor can understand. This format is 
referred to as Machine Language. For most 
microprocessors this instruction is a group 
of 8 binary bits (1's and O's) called a word 
(also called a byte if the word is 8-bits). Some 
instructions require more than one location 
in Program Memory. To execute a multi-byte 
instruction, the processor must execute 
multiple fetches of program memory before 
performing the instruction. Because multi- 
byte instructions take more Program Mem- 
ory and take longer to execute than single 
byte instructions their use is usually kept to a 
minimum. 

A processor may be programmed by 
writing a sequence of instructions in the 
binary code (ones and zeros) which the 
machine can interpret directly. This is 
machine language programming and it is 
very useful where the program to be written 
is small and the application requires that 
the designer have an intimate knowledge of 
the microprocessor. Machine language pro- 
gramming allows the user, because of his 
detailed knowledge, to use many program- 
ming "tricks" to produce the most compact 
and efficient code possible. 

The following is an example of a machine 
language program: This program reads 5 
sequential 8-bit words in from an I/O port 
and stores them sequentially in data 
memory. The program starts by initializing 
two registers, one which determines where 
the data is to be stored and another which 



counts the number of words to be stored. 
When finished the processor continues on 
to the next instructions. 



Step 
Number 



Machine 
Code 



Explanation 



6 


0001 1000 


7 


1110 1010 


8 


0000 0100 


9 




10 


— ■ 



1011 1000 Load decimal 32 in 

1 0010 0000 register R0 

2 1011 1010 Load decimal 5 in 

3 0000 0101 register R2 

4 0000 1001 Load Port 1 to accu- 

mulator 

5 1111 0000 Transfer contents of 

accumulator to reg- 
ister addressed by 
register 

Increment R0 by 1 

Decrement register 2 
by 1, if result is zero 
continue to step 9, if 
not go to step 4 



As you can see, writing machine instruc- 
tions in ones and zeros can be very 
laborious and subject to error. It is almost 
always more efficient to represent each 8- 
bits if machine language code in a 
shorthand format called Hexadecimal. 
The term hexadecimal results from the 
character set used in hexadecimal notation. 
Hexadecimal is merely an extension of the 
normal decimal numbers by the addition of 
the first six letters of the alphabet. This 
gives a total of 1 6 different characters. Each 
hexadecimal "digit" can represent 16 
values or the equivalent of four binary bits; 
therefore, each 8-bit machine language 
word can be represented by 2 hexadecimal 
(hex for short) digits. The correspondence 
among the decimal, binary, and hex 
number systems is given below: 
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Decimal 



Hex 



Binary 




1 
2 
3 
4 
5 
6 
7 
8 
9 

10 
11 
12 
13 
14 
15 



0000 
0001 
0010 
0011 
0100 
0101 
0110 
0111 
1000 
1001 
1010 
1011 
1100 
1101 
1110 

1111 



Our machine language program then 
becomes: 



Step 


Hex Code 





B8 


1 


20 


2 


BA 


3 


05 


4 


09 


5 


F0 


6 


18 


7 


EA 


8 


04 



This coding is now quite efficient to write 
and read and coding errors are much easier 
to detect. Hex coding is usually very 
efficient for small programs (afew hundred 
lines of code) however, it does have two 
major limitations in larger programs: 

1. Hex coding is not self-documenting, that 
is, the code itself does not give any indication 
in human terms of the operation to be 
performed. The user must learn each code or 
constantly use a Program Reference Card to 
convert. 

2. Hex coding is absolute, that is, the 
program will work only when stored in a 
specific location in program memory. This is 
because the branch or jump instructions in 
the program reference specific addresses 
elsewhere in the program. In the example 
above steps 7 and 8 reference step (or 
address) 4. If the program were to be moved, 



step 8 would have to be changed to refer to 
the new address of step 4. 

1.2.2 Assembly Language Programming 

Assembly language overcomes the dis- 
advantages of machine language by allowing 
the use of alphanumeric symbols to repre- 
sent machine operation codes, branch 
addresses, and other operands. For example, 
the instruction to increment the contents of 
register becomes INC R0 instead of the hex 
18, giving the user at a glance the meaning of 
the instruction. Our example program can be 
written in assembly language as follows: 



Step No. Hex Code 



Assembly Code 



B8 
20 
BA 
05 
09 
F0 
18 
EA 
04 



INP: 



MOV R0, #32 

MOV R2, #05 

IN A, P1 
MOV @R0, A 
INC R0 
DJNZ R2, INP 



The first statement can be verbalized as 
follows: Move to Register the decimal 
number 32. Move instructions are always 
structured such that the destination is first 
and the source is second. The pound sign "#" 
indicates that the source is "immediate" data 
(data contained in the following byte of 
program memory). In this case data was 
specified as a decimal 32, however, this could 
have been written as a hex 20H or a binary 
0010 0000B since the assembler will accept 
either form. Notice also that in this instance 
two lines of hex code are represented by one 
line of assembly code. 

The input instruction IN A, P1 has the same 
form as a MOV instruction indicating that the 
contents of Port 1 are to be transferred to the 
accumulator. In front of the input instruction 
is an address lable which is delineated by a 
colon. This lable allows the program to be 
written in a form independent of its final 
location in program memory since the 
branch instruction at the end of the program 
can refer to this lable rather than a specific 
address. This is a very important advantage 
of assembly language programs since it 
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allows instructions to be added or deleted 
throughout the program during debugging 
without requiring that any jump addresses be 
changed. 

The next instruction MOV @R0, A can be 
verbalized as, Move to the data memory 
location addressed by RO, the contents of the 
accumulator. The @ sign indicates an 
indirect operation whereby the contents of 
either register or register 1 acts as a pointer 
to the data memory location to be operated 
on. 

The last instruction is a Decrement and Jump 
if Not Zero instruction which acts in 
combination with the specified register as a 
loop counter. In this case register 2 is loaded 
with 5 initially and then decremented by one 
each time the loop is executed. If the result of 
the decrement is not zero, the program jumps 
to INP and executes another input operation. 
The fifth time thru the loop the result is zero 
and execution falls through to whatever 
routine follows the DJNZ instruction. 

In addition to the normal features provided 
by assemblers, more advanced assemblers 
such as that for the MCS-48 offer such things 
as evaluation of expressions at assembly 
time, conditional assembly, and macro 
capability. 

1. Evaluation of Expressions - Certain 
assemblers allow the use of arithmetic 
expressions and multiple symbols in the 
operand portion of instructions. For instance 
the MCS-48 assembler accepts instructions 
such as: 

ADD A, # ALFA*BETA/2 

ALFA and BETA are two previously defined 
symbols. At assembly time the expression 
ALFA*BETA/2 will be evaluated and the 
resulting number (which is the average of 
ALFA and BETA) will be treated as 
immediate data and designated as the 
second byte of the ADD immediate instruc- 
tion. This expression has allowed the 
immediate data of this instruction to be 
defined in a single statement and eliminated 
the need for a third symbol equal to 
ALFA* BETA/2. 



2. Conditional Assembly - Conditional as- 
sembly allows the programmer to select only 
certain portions of his assembly language 
(source) program for conversion to machine 
(object) code at assembly time. This allows 
for instance/the inclusion of various "debug" 
routines to be included in the program during 
development. Using conditional assembly, 
they can then be left out when the final 
assembly is done. 

Conditional assembly also allows several 
versions of one basic program to be 
generated by selecting various portions of a 
larger program at assembly time. 

3. Macro's - A macro instruction is essen- 
tially a symbol which is recognized by the 
assembler to represent a specific sequence 
of several standard instructions. A macro is a 
shorthand way of generating the same 
sequence of instructions at several locations 
in a program without having to rewrite the 
sequence each time it is used. For example, a 
typical macro instruction might be one which 
performs a subtract operation. The 8048 does 
not have a subtract instruction as such but 
the operation can be performed easily with 
three instructions: 

CPL A 

ADD A, REG 
CPL A 

This routine subtracts a register from the 
accumulator and leaves the result in the 
accumulator. This sequence can be defined 
as a macro with the name SUB and an 
operand which can be RO to R7. To subtract 
R7 from the accumulator then, the program- 
mer merely has to write: 

SUB R7 

and the assembler will automatically insert 
the three instructions above with R7 substi- 
tuted for REG. 

Once the assembly language source code is 
written it can be converted to machine 
executable object code by passing it through 
an assembler program. The MCS-48 assem- 
bler is a program which runs on the 8080- 
based Intellec MDS system explained in the 
next section. 
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1.3 Developing An MCS-48™ Based 
Product 

Although the development of a microcom- 
puter based product may differ in detail from 
the development cycle of a product based on 
TTL logic or relays, the basic procedures are 
the same — only the tools are different. 

1.3.1 Education 

The first step of course is to become familiar 
with what the microcomputer is and what it 
can do. The first step in this education is this 
document, the MCS-48™ User's Manual. The 
user's manual gives a detailed description of 
the MCS-48 family of components and how 
they may be used in various system configu- 
rations. Also included is a description of the 
8048 instruction set and examples of 
how the instructions may be used. For a more 
complete discussion of the instruction set 
and programming techniques the MCS-48 
Assembly Language Manual is also available. 

If time is critical in getting started in 
microcomputers, individuals can attend one 
of many Intel sponsored 3-day training 
courses which give basic instruction in the 
MCS-48 as well as hands-on experience with 
MCS-48 development systems. These 
courses are a convenient means of getting 
started with the MCS-48, particularly for 
those not familiar with microprocessors. 

After general familiarization is complete, 
either through self-instruction or a training 
course, the next step is to gain a better "feel" 
for what a microprocessor can do in your 
own applications by writing several exercise 
programs which perform basic functions. 
You may require such things as I/O routines, 
delays, counting functions, look-up tables, 
arithmetic functions, and logical operations 
which can serve as a set of building blocks for 
future applications programs. Several basic 
programming examples are included in the 
MCS-48 Assembly Language Manual while 
the Intel User's Library is a source of more 
specific applications routines. 

1.3.2 Function Definition 

After a thorough understanding of the 



microprocessor is achieved, the functions to 
be implemented can be defined using a 
flowchart method to describe each basic 
system function and the sequence in which 
the processor executes these functions. 
Once the system is flowcharted, critical time- 
related functions can be identified and 
sample programs written to verify that 
performance requirements can be met. 

1.3.3 Hardware Configuration 

The next step involves the definition of the 
microcomputer hardware required to imple- 
ment the function. Input/Output capability 
must be defined in terms of number of inputs, 
number of outputs, bi-directional lines, 
latching or non-latching I/O, output drive 
capability, and input impedance. The num- 
ber of words of RAM storage required for 
intermediate results and data storage must 
then be determined. The type of system will 
dictate whether battery backup is needed to 
maintain data RAM during power failure. 

Probably the most difficult parameter to 
define initially is the amount of program 
memory needed to store the applications 
program. Although previously written exer- 
cise programs will make this estimate more 
accurate, a generous amount of "breathing 
room" should be allowed in program memory 
until coding is complete and the exact 
requirements are known. Many special 
functions such as serial communications 
(TTY) or keyboard/display interfaces may be 
implemented in software (programs); how- 
ever, in cases where these functions place a 
severe load on the processor in terms of time 
or program memory, special peripheral 
interface circuits such as the 8251, Universal 
Synchronous or Asychronous Receiver/ 
Transmitter (USART) or 8279 Keyboard/ 
Display interface may be used. 

1.3.4 Code Generation 

The writing of the final program code for the 
application can begin once the system 
function and hardware have been defined 
and can be generated in parallel with the 
detailed hardware design (PC card layout, 
power supply, etc.) 
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At this point, there are two paths available to 
the designer/programmer and two types of 
design development aids provided by Intel to 
simplify the procedures. One system, called 
PROMPT 48, is a low cost development 
system which supports machine language 
programming and the second is the Intellec 
Microcomputer Development System which 
supports both machine and assembly langu- 
ages. For those of you unfamiliar with the 
advantages and disadvantages of machine 
and assembly languages see Section 1.2. 

1.3.5 PROMPT 48 

PROMPT 48 is a low cost design aid 
consisting of: an 8748 processor to execute 
programs, control circuitry to provide debug 
functions such as single step and break 
points, a monitor program stored in ROM, 
an EPROM programmer, and a hexa- 
decimal keyboard and display. There are two 
processor sockets on the front of PROMPT 
48, one for programming the 8748 and one in 



which a programmed 8748 executes its 
program while under control of the monitor 
routine. 

Use of PROMPT 48 involves the following 
steps: 

1. Loading an application program into the 
PROMPT RAM memory via Hex keyboard or 
external terminal (TTY and RS232 interface 
provided). 

2. Inserting an erased 8748 in the program- 
ming socket and transferring the application 
program to its internal EPROM. 

3. Transferring programmed 8748 to execu- 
tion socket where program is executed and 
debugged under control of the monitor. 

The monitor routine allows the user to single 
step this processor, examine or modify all 
internal registers and data memory; or to run 
at full speed and stop the processor at 
predetermined breakpoints. PROMPT 48 
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also provides 1K of writeable program 
memory which may be used to debug user 
programs. A multiple single step feature 
is also provided in which the processor steps 
through its program dumping all iritemal 
contents to external RAM where it may be 
later displayed or typed out on an external 
terminal. Paper tape input and output in 
Intel's hexadecimal format is also available 
through the TTY. 

1.3.6 Intellec Development System 

The Intellec Microcomputer Development 
System is a modular development system 
which can be expanded as necessary to meet 
the requirements of your design cycle. The 
system consists of the processor unit which 
is based on Intel's 8080A microprocessor, 
and several optional units such as the UPP 
Universal PROM Programmer, the PTR High 
Speed Paper tape reader, the DOS Disk 
Operating System, and the Intellec CRT 
terminal. 

To support the development of MCS-48 
systems a macro-assembler ASM 48 is 
available for the Intellec System as well as a 
personality module for the UPP which will 
program the EPROM of the 8748. Also to be 
provided is in-circuit emulation capability 
with ICE-48 which will allow emulation and 
debug of user's 8048 application programs 
on the 8080A-based Intellec Development 
System. 

The Intellec system is a flexible high 
performance development system which can 
support Intel's various microcomputer fami- 
lies with various optional modules. The 



macro-assembler and text editor programs 
provided allow the designer to write and edit 
his programs in assembly language and then 
generate the machine language output 
necessary to program the 8748 EPROM. The 
availability of a high speed CRT and a 
diskette operating system eliminates the 
laborious input and output of paper tape files 
normally required during the assembly 
process. Finally, ICE 48 allows the user to 
extend the resources of his entire Intellec 
system into the 8048 socket of his own 
system and use all its emulation, debug, and 
display facilities directly. 

1.3.7 Production 

Once a working program has been achieved, 
a preproduction phase usually follows where 
several prototype systems are evaluated in 
simulated situations or in actual operation in 
the field. During this period the use of the 
8748 EPROM allows quick alteration of the 
application program when problems or 
suggested changes arise. Depending on the 
magnitude and number of future changes 
anticipated, the first production units may 
also be shipped with EPROM processor. 
However, to achieve the maximum cost 
reduction potential in high volume appli- 
cations, a conversion to the 8048 ROM is 
usually necessary. This is an easy transition 
since the 8048 and 8748 are pin and machine 
code compatible equivalents. The user 
merely develops a hexadecimal tape of his 
8748 program memory contents using his 
Intellec System or PROMPT 48 development 
aid and sends it to Intel along with his 8048 
order. As the 8048 ROM's arrive they can 
immediately replace the 8748 EPROMs. 



THE SINGLE COMPONENT MCS-48" SYSTEM 




THE SINGLE COMPONENT MCS-48™ SYSTEM 



SECTION 1: 8048/8748/8035 and 8049/8039 

2.0 Summary 2-1 

2.1 Architecture 2-1 

2.2 Pin Description 2-14 

2.3 Programming, Verifying and Erasing EPROM 2-16 

2.4 Test and Debug 2-18 



SECTION 2: 8021 

2.5 Program Memory 2-21 

2.6 Data Memory 2-21 

2.7 Oscillator and Clock ... 2-22 

2.8 Timer/Event Counter 2-22 

2.9 Input/Output Capabilities 2-23 

2.10 CPU 2-25 

2.1 1 Reset 2-25 



THE SINGLE COMPONENT MCS-48™ SYSTEM 



2.0 Summary 

Sections 2.1 through 2.4 describe in detail 
the functional characteristics of the 8748 
EPROM, 8048/8049 ROM and 8035/8039 
single component microcomputers. Unless 
otherwise noted, details within these 
sections apply to all versions. Sections 2.5 
through 2.11 describe the operation of the 
8021. This chapter is limited to those 
functions useful in single-chip implemen- 
tations of the MCS-48. Chapter 3 discusses 
functions which allow expansion of pro- 
gram memory, data memory, and input- 
output capability. 

2.1 Architecture 

The following sections break the 8048 into 
functional blocks and describe each in detail. 

2.1.1 Arithmetic Section 

The arithmetic section of the processor con- 
tains the basic data manipulation functions of 
the 8048 and can be divided into the following 

blocks: 

Arithmetic Logic Unit (ALU) 

Accumulator 

Carry Flag 

Instruction Decoder 

In a typical operation data stored in the 
accumulator is combined in the ALU with data 
from another source on the internal bus (such 
as a register or I/O port) and the result is 
stored in the accumulator or another register. 
The following is a more detailed description of 
the function of each block: 

Instruction Decoder 

The operation code (op code) portion of each 
program instruction is stored in the Instruction 
Decoder and converted to outputs which 
control the function of each of the blocks of 
the Arithmetic Section. These lines control 
the source of data and the destination register 
as well as the function performed in the ALU. 



Arithmetic Logic Unit 

The ALU accepts 8-bit data words from one 
or two sources and generates an 8-bit result 
under control of the Instruction Decoder. 
The ALU can perform the following functions: 



Add With or Without Carry 
And, OR, Exclusive OR 
Increment/Decrement 
Bit Complement 
Rotate Left, Right 
Swap Nibbles 
BCD Decimal Adjust 



If the operation performed by the ALU results 
in a value represented by more than 8 bits 
(overflow of most significant bit) a Carry Flag 
is set in the Program Status Word. 

Accumulator 

The accumulator is the single most important 
data register in the processor being one of the 
sources of input to the ALU and often the 
destination of the result of operations per- 
formed in the ALU. Data to and from I/O ports 
and memory also normally passes through 
the accumulator. 

2.1.2 Program Memory 

Resident program memory consists of 1024 
or 2048 words eight bits wide which are 
addressed by the program counter. In the 
8748 this memory is user programmable 
and erasable EPROM, in the 8048/8049 the 
memory is ROM which is mask program- 
mable at the factory, while the 8035/8039 
has no internal program memory and is 
used with external devices. Program code 
is completely interchangeable among the 
various versions. See Section 2.3 for 
EPROM programming techniques. 
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There are three locations in Program Memory 
of special importance: 

LOCATION 
Activating the Reset line of the processor 
causes the first instruction to be fetched 
from location 0. 

LOCATION 3 
Activating the Interrupt input line of the 
processor (if interrupt is enabled) causes a 
jump to subroutine. 

LOCATION 7 
A timer/counter interrupt resulting from 
timer/counter overflow (if enabled) causes 
a jump to subroutine. 

Therefore, the first instruction to be executed 
after initialization is stored in location 0, the 
first word of an external interrupt service 
subroutine is stored in location 3, and the first 
word of a timer/counter service routine is 
stored in location 7. Program memory can be 
used to store constants as well as program 
instructions. Instructions such as MOVP and 
MOVP3 allow easy access to data "lookup" 
tables. 

Data Memory 

Resident data memory is organized as 64 or 
128 words 8-bits wide. All locations are 
indirectly addressable through either of 
two RAM Pointer Registers which reside at 
address and 1 of the register array. In 
addition, the first 8 locations (0-7) of the 
array are designated as working registers 
and are directly addressable by several 
instructions. Since these registers are more 
easily addressed, they are usually used to 
store frequently accessed intermediate 
results. The DJNZ instruction makes very 
efficient use of the working registers as pro- 
gram loop counters by allowing the 
programmer to decrement and test the 
register in a single instruction. 

By executing a Register Bank Switch instruc- 
tion (SEL RB) RAM locations 24-31 are 
designated as the working registers in place 
of locations 0-7 and are then directly address- 
able. This second bank of working registers 
may be used as an extension of the first bank 
or reserved for use during interrupt service 
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subroutines allowing the registers of Bank 
used in the main program to be instantly 
"saved" by a Bank Switch. Note that if this 
second bank is not used, locations 24-31 are 
still addressable as general purpose RAM. 
Since the two RAM pointer Registers RO and 
R1 are a part of the working register array, 
bank switching effectively creates two more 
pointer registers (RO' and R1') which can be 
used with RO and R1 to easily access up to 
four separate working areas in Ram at one 
time. RAM locations (8-23) also serve a dual 
role in that they contain the program counter 
stack as explained in Sec. 2.1.6. These loca- 
tions are addressed by the Stack Pointer 
during subroutine calls as well as by RAM 
Pointer Registers RO and R1. If the level of 
subroutine nesting is less than 8, all stack 
registers are not required and can be used as 
general purpose RAM locations. Each level of 
subroutine nesting not used provides the user 
with two additional RAM locations. 

2.1.4 Input/Output 

The 8048 has 27 lines which can be used for 
input or output functions. These lines are 
grouped as 3 ports of 8 lines each which 
serve as either inputs, outputs or bidirectional 



ports and 3 "test" inputs which can alter 
program sequences when tested by conditional 
jump instructions. 

Ports 1 and 2 

Ports 1 and 2 are each 8 bits wide and have 
identical characteristics. Data written to these 
ports is statically latched and remains un- 
changed until rewritten. As input ports these 
lines are non latching, i.e., inputs must be 
present until read by an input instruction. 
Inputs are fully TTL compatible and outputs 
will drive one standard TTL load. 

The lines of ports 1 and 2 are called quasi- 
bidirectional because of a special output 
circuit structure which allows each line to 
serve as an input, an output, or both even 
though outputs are statically latched. The 
figure shows the circuit configuration in detail. 
Each line is continuously pulled up to +5v 
through a resistive device of relatively high 
impedance (~50Kn). This pullup is sufficient 
to provide the source current for a TTL high 
level yet can be pulled low by a standard TTL 
gate thus allowing the same pin to be used for 
both input and output. To provide fast switching 
times in a "0" to "1" transition a relatively low 
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impedance device (~5Kfl) is switched in 
momentarily (~500ns) whenever a "1" is 
written to the line. When a "0" is written to the 
line a low impedance (-300O) device over- 
comes the light pullup and provides TTL 
current sinking capability. Since the pulldown 
t ransistor is a low impedance device a "1" 
must first be writte n to any Ijne which JsJo.be 
usecTas an input. Reset initializes aJMjnesJa 
the high impeda nce "1" state. This structure 
anowsTnpu'ran^ same pin and 

also allows a mix of input lines and output 
lines on the same port. The quasi-bidirectional 
port in combination with the ANL and ORL 
logical instructions provide an efficient means 
for handling single line inputs and outputs 
within an 8-bit processor. See also Section 
3.7. 

Bus 

Bus is also an 8-bit port which is a true bi- 
directional port with associated input and 
output strobes. If the bidirectional feature is 
not needed, Bus can serve as either a statically 
latched output port or non-latching input port. 
Input and output lines on this port cannot be 
mixed however. 

As a static port, data is written and latched 
using the OUTL instruction and inputted using 
the INS instruction. The INS and OUTL instruc- 
tions generate pulses on the corresponding 
RD and WR output strobe lines; however, in 
the static port mode they are generally not 
used. As a bidirectional port the MOVX instruc- 
tions are used to read and write the port. A 
write to the port generates a pulse on the WR 
output line and output data is valid at the 
trailing edge of WR. A_read of the port 
generates a pulse on the RD output line and 
input data must be valid at the trailing edge of 
RD. When not being written or read, the BUS 
lines are in a high impedance state. See also 
Sections 3.6 and 3.7. 

2.1.5 Test and INT Inputs 

Three pins serve as inputs and are testable 
with the conditi onal jump instruction. These 
are TO, T1, and INT These pins allow inputs 



to cause program branches without the neces- 
sity to load an input port into the accumulator. 
The TO, T1, and INT pins have other possible 
functions as well. See the pin description in 
Sec. 2.2. 

2.1.6 Program Counter and Stack 

The Program Counter is an independent 
counter whilethe Program Counter Stack is 
implemented using pairs of registers in the 
Data Memory Array. Only 10 (or 11) bits of 
the Program Counter are used to address 
the 1024 (2048) words of on-board program 
memory while the most significant bits are 
used for external Program Memory fetches. 
The Program Counter is initialized to zero 
by activating the Reset line. 

An interrupt or CALL to a subroutine causes 
the contents of the program counter to be 
stored in one of the 8 register pairs of the 
Program Counter Stack. The pair to be used 
is determined by a 3-bit Stack Pointer which 
is part of the Program Status Word (PSW). 
Data RAM locations 8 thru 23 are available as 
stack registers and are used to store the 
Program Counter and 4 bits of PSW as 
shown in the figure. The Stack Pointer when 
initialized to 000 points to RAM locations 
8 and 9. The first subroutine jump or interrupt 
results in the program counter contents being 
transferred to locations 8 and 9 of the RAM 
array. The stack pointer is then incremented 
by one to point to locations 10 and 11 in 
anticipation of another CALL. Nesting of sub- 
routines within subroutines can continue up to 
8 times without overflowing the stack. If 
overflow does occur the deepest address 
stored (location 8 and 9) will be overwritten 
and lost since the stack pointer overflows 
from 111 to 000. It also underflows from 000 
to 111. 

The end of a subroutine, which is signalled by 
a return instruction (RET or RETR), causes 
the Stack Pointer to be decremented and the 
contents of the resulting register pair to be 
transferred to the Program Counter. 
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2.1.7 Program Status Word 

An 8-bit status word which can be loaded to 
and from the accumulator exists called the 
Program Status Word (PSW). The accom- 
panying figure shows the information available 
in the word. The Program Status Word is 
actually a collection of flip-flops throughout 
the machine which can be read or written as a 
whole. The ability to write to PSW allows for 
easy restoration of machine status after a 
power down sequence. 

The upper four bits of PSW are stored in the 
Program Counter Stack with every call to 
subroutine or interrupt vector and are optionally 
restored upon return with the RETR instruction. 
The RET return instruction does not update 
PSW. 

The PSW bit definitions are as follows: 

Bits - 2: Stack Pointer bits (S , S^ S 2 ) 

Bit 3: Not used ("1" level when 

read) 

Bit 4: Working Register Bank Switch 

Bit (BS) 

= Bank 

1 = Bank 1 

Bit 5: Flag bit (F0) user controlled 

flag which can be comple- 
mented or cleared, and tested 
with the conditional jump in- 
struction JF0. 

Bit 6: Auxiliary Carry (AC) carry bit 

generated by an ADD instruc- 
tion and used by the decimal 
adjust instruction DA A. 

Bit 7: Carry (CY) carry flag which 

indicates that the previous 
operation has resulted in over- 
flow of the accumulator. 

2.1.8 Conditional Branch Logic 

The conditional branch logic within the pro- 
cessor enables several conditions internal 
and external to the processor to be tested by 
the users program. By using the conditional 
jump instruction the following conditions can 
effect a change in the sequence of the 
program execution. 
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2.1.9 Interrupt 

An interrupt sequence is initiated by applying 
a low "0" level input to the INT pin. Interrupt is 
level triggered and active low to allow "WIRE 
ORing" of several interrupt sources at the 
input pin. The Interrupt line is sampled every 
machine cycle during ALE and when detected 
causes a "jump to subroutine" at location 3 in 
program memory as soon as all cycles of the 
current instruction are complete. As in any 
CALL to subroutine, the Program Counter 
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and Program Status word are saved in the 
stack. For a description of this operation see 
the previous section, Program Counter and 
Stack. Program Memory location 3 usually 
contains an unconditional jump to an interrupt 
service subroutine elsewhere in program 
memory. The end of an interrupt service 
subroutine is signalled by the execution of a 
Return and Restore Status instruction RETR. 
The interrupt system is single level in that 
once an interrupt is detected all further inter- 
rupt requests are ignored until execution of an 
RETR re-enables the interrupt input logic. 
This occurs at the beginning of the second 
cycle of the RETR instruction. This sequence 
holds true also for an internal interrupt gener- 
ated by timer overflow. If an internal timer/ 
counter generated interrupt and an external 
interrupt are detected at the same time, the 
external source will be recognized. See the 
following Timer/Counter section for a descrip- 
tion of timer interrupt. If needed, a second 
external interrupt can be created by enabling 
the timer/counter interrupt, loading FFH in the 
Counter (one less than terminal count), and 
enabling the event counter mode. A "1" to "0" 
transition on the T1 input will then cause an 
interrupt vector to location 7. 

Interrupt Timing 

The interrupt input may be enabled or disabled 
under Program Control using the EN I and 
DIS I instructions. Interrupts are disabled by 
Reset and remain so until enabled by the 
users program. An interrupt request must be 
removed before the RETR instruction is ex- 
ecuted upon return from the service routine 
otherwise the processor will re-enter the ser- 
vice routine immediately. Many peripheral 
devices prevent this situation by resetting 
their interrupt request line whenever the pro- 
cessor accesses (Reads or Writes) the periph- 
erals data buffer register. If the interrupting 
device does not require access by the pro- 
cessor, one output line of the 8048 may be 
designated as an "interrupt acknowledge" 
which is activated by the service subroutine to 
reset the interrupt request. The INT pin may 
also be tested using the conditional jump 
instruction JNI. This instruction may be used 



to detect the presence of a pending interrupt 
before interrupts are enabled. If interrupt is 
left disabled, INT may be used as another test 
input like TO and T1. 

2.1.10 Timer/Counter 

The 8048 contains a counter to aid the user in 
counting external events and generating ac- 
curate time delays without placing a burden 
on the processor for these functions. In both 
modes the counter operation is the same, the 
only difference being the source of the input 
to the counter. 

Counter 

The 8-bit up binary counter is presettable and 
readable with two MOV instructions which 
transfer the contents of the accumulator to the 
counter and vice versa. T he counter content is 
noLaffected, by Reset and i s initialize d solely 
by.Jh.e.MQ^ The counter is 

stopped by a Reset or STOPTCNT instruction 
and remains stopped until started as a timer 
by a START T instruction or as an event 
counter by a START CNT instruction. Once 
started the counter will increment to its maxi- 
mum count (FF) and overflow to zero contin- 
uing its count until stopped by a STOP TCNT 
instruction or Reset. 

The increment from maximum count to zero 
(overflow) results in the setting of an overflow 
flag flip-flop and in the generation of an 
interrupt request. The state of the overflow 
flag is testable with the conditional jump 
instruction JTF. The flag is reset by executing 
a JTF or by Reset. The interrupt request is 
stored in a latch and then ORed with the 
external interrupt input INT The timer interrupt 
may be enabled or disabled independently of 
external interrupt by the EN TCNTI and DIS 
TCNTI instructions. If enabled, the counter 
overflow will cause a subroutine call to location 
7 where the timer or counter service routine 
may be stored. If timer andexternal interrupts 
occur simultaneously, the external source will 
be recognized and the Call will be to location 
3. Since the timer interrupt is latched it will 
remain pending until the external device is 
serviced and immediately be recognized upon 
return from the service routine. The 
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pending timer interrupt is reset by the Call 
to location 7 or may be removed by 
executing a DIS TCNTI instruction. 

As an Event Counter 

Execution of a START CNT instruction con- 
nects the T1 input pin to the counter input and 
enables the counter. Subsequent high to low 
transitions on T1 will cause the counter to 
increment. The maximum rate at which the 
counter may be incremented is once per 
three instruction cycles (every 7.5/asec when 
using a 6MHz crystal) — there is no minimum 
frequency. T1 input must remain high for at 
least 500ns (at 6MHz) after each transition. 

As a Timer 

Execution of a START T instruction connects 
an internal clock to the counter input and 
enables the counter. The internal clock is 
derived by passing the basic 400 KHz machine 
cycle clock ALE through a + 32 prescaler. 
The prescaler is reset during the START T 
instruction. The resulting 12.5 KHz clock 
increments the counter every 80 ^sec 
(assuming 6 MHz XTAL). Various delays 
between 80 /xsec and 20 msec (256 counts) 
can be obtained by presetting the counter and 
detecting overflow. Times longer than 20 
msec may be achieved by accumulating mul- 



tiple overflows in a register under software 
control. For time resolution less than 80 /xsec 
an external clock can be applied to the T1 
input and the counter operated in the event 
counter mode. ALE divided by 3 or more can 
serve as this external clock. Very small delays 
or "fine tuning" of larger delays can be easily 
accomplished by software delay loops. 

2.1.11 Clock and Timing Circuits 

Timing generation for the 8048 is completely 
self-contained with the exception of a fre- 
quency reference which can be XTAL, 
inductor, or external clock source. The 
Clock and Timing circuitry can be divided 
into the following functional blocks: 

Oscillator 

The on-board oscillator is a high gain series 
resonant circuit with a frequency range of 1 to 
6MHz. The X1 external pin is the input to the 
amplifier stage while X2 is the output. A 
crystal or inductor connected between X1 
and X2 provides the feedback and phase 
shift required for oscillation. A 5.9904 MHz 
crystal provides for easy derivation of all 
standard communications frequencies. If an 
accurate frequency reference and maximum 
processor speed are not required, an induc- 
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tor may be used in place of the crystal. With 
an inductor the oscillator frequency can be 
approximately 3 to 5 MHz. For higher speed 
operation a crystal should be used. An 
externally generated clock may also be 
applied to X1-X2 as the frequency source. 



State Counter 

The putput^of .the ,QscillatorJs.diYid^d_bx3^ in 
the State Counter to create a clock which 
defi nes the state times of the machine (CLK) . 
CLK can blTmade available on the external 
pin TO by executing an ENTO CLK instruction. 
The output of CLK on TO is disabled by Reset 
of the processor. 



Cycle Counter 

CLK is then divided by 5 in the Cycle Counter 
to provide a clock which d efines a machine 
cycle consistin g Ql, 5jTiachln^_sJales. This 
cloWTs called Address Latch Enable (ALE) 
because of its function in MCS-48 systems 
with external memory. It is provided continu- 
ously on the ALE output pin. 

2.1.12 Reset 

The reset input provides a means for initializa- 
tion for the processor This Schmitt-trigger 
input has an internal pullup resistor which in 
combination with an external 1 £ifd capacitor 
provides an internal reset pulse of sufficient 
length to guarantee all circuitry is reset. If the 
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FETCH 
INSTRUCTION 


INCREMENT 
PROGRAM COUNTER 





INCREMENT 
TIMER 


OUTPUT 
TO PORT 

















ANL BUS. -DATA 


FETCH 
INSTRUCTION 


INCREMENT 
PROGRAM COUNTER 





INCREMENT 
TIMER 


READ PORT 


FETCH 
IMMEDIATE DATA 





INCREMENT 
PROGRAM COUNTER 


OUTPUT 
TO PORT 





ORL BUS, -DATA 


FETCH 
INSTRUCTION 


INCREMENT 
PROGRAM COUNTER 





INCREMENT 
TIMER 


READ PORT 


FETCH 
IMMEDIATE DATA 





INCREMENT 
PROGRAM COUNTER 


OUTPUT 
TO PORT 





MOVX 19 R.A 


FETCH 
INSTRUCTION 


INCREMENT 
PROGRAM COUNTER 


OUTPUT RAM 
ADDRESS 


INCREMENT 
TIMER 


OUTPUT 
DATA TO RAM 






* 






MOVX A,@R 


FETCH 
INSTRUCTION 


INCREMENT 
PROGRAM COUNTER 


OUTPUT RAM 
ADDRESS 


INCREMENT 
TIMER 








READ DATA 











MOVD A.P; 


FETCH 
INSTRUCTION 


INCREMENT 
PROGRAM COUNTER 


OUTPUT 
OPCODE/ADDRESS 


INCREMENT 
TIMER 








READ 
P2 LOWER 











MOVD P;, A 


FETCH 
INSTRUCTION 


INCREMENT 
PROGRAM COUNTER 


OUTPUT 
OPCODE/ADDRESS 


INCREMENT 
TIMER 


OUTPUT DATA 
TOP2 LOWER 












ANLD P. A 


FETCH 
INSTRUCTION 


INCREMENT 
PROGRAM COUNTER 


OUTPUT 
OPCODE/ADDRESS 


INCREMENT 
TIMER 


OUTPUT 
DATA 












ORLD P.A 


FETCH 
INSTRUCTION 


INCREMENT 
PROGRAM COUNTER 


OUTPUT 
OPCODE/ADDRESS 


INCREMENT 
TIMER 


OUTPUT 
DATA 






" 







J (CONDITIONAL) 


FETCH 
INSTRUCTION 


INCREMENT 
PROGRAM COUNTER 


SAMPLE 
CONDITION 


INCREMENT 
TIMER 





FETCH 
IMMEDIATE DATA 





UPDATE 
PROGRAM COUNTER 








STRT T 
STRT CNT 


FETCH 
INSTRUCTION 


INCREMENT 
PROGRAM COUNTER 








START 
COUNTER 




STOP TCNT 


FETCH 
INSTRUCTION 


INCREMENT 
PROGRAM COUNTER 








STOP 
COUNTER 




ENI 


FETCH 
INSTRUCTION 


INCREMENT 
PROGRAM COUNTER 





ENABLE 
INTERRUPT 







DISI 


FETCH 
INSTRUCTION 


INCREMENT 
PROGRAM COUNTER 


. 


DISABLE 
INTERRUPT 





*VALID INSTRUCTION ADDRESSES ARE OUTPUT AT THIS TIME 


ENTO CLK 


FETCH 
INSTRUCTION 


INCREMENT 
PROGRAM COUNTER 





ENABLE 
CLOCK 





IF EXTERNAL PROGRAM MEMORY IS BEING ACCESSED. 



INSTRUCTION TIMING DIAGRAM 
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reset pulse is generated externally the reset 
pin must be held at ground (.5V) for at least 
50 milliseconds after the power supply is 
within tolerance. Only 5 machine cycles 
(12.5)us @ 6 MHz) are required if power is 
already on and the oscillator has stabilized. 

EXTERNAL RESET 



— E» 



POWER ON RESET 



T 

T 



Reset performs the following functions: 

1. Sets program counter to zero. 

2. Sets stack pointer to zero. 

3. Selects register bank 0. 

4. Selects memory bank 0. 

5. Sets BUS to high impedance state, 
(except when EA = 5V) 

6. Sets Ports 1 and 2 to input mode. 

7. Disables interrupts (timer and external) 

8. Stops timer. 

9. Clears timer flag. 

10. Clears F0 and F1. 

11. Disables clock output from TO. 

2.1.13 Single-Step 

This feature provides the user with a debug 
capability in that the processor can be stepped 
through the program one instruction at a time. 
While stopped, the address of the next instruc- 
tion to be fetched is available concurrently on 
BUS and the lower half of Port 2. The user 
can therefore follow the program through 
each of the instruction steps. A timing diagram, 
showing the interaction between output ALE 
and input SS is shown. The BUS buffer 
contents are lost during single step, however, 
a latch may be added to re-establish the lost 
I/O capability if needed. (See 2.4.1). 



Timing 

The 8048 operates in a single-step mode as 
follows: 

1. The processor is requested to stop by 
applying a low level on SS. 

2. The processor responds by stopping 
during the instruction fetch portion of the 
next instruction. If a double cycle instruc- 
tion is in progress when the single step com- 
mand is received, both cycles will be com- 
pleted before stopping. 

3. The processor acknowledges it has 
entered the stopped state by raising ALE 
high. In this state (which can be maintained 
indefinitely) the address of the next instruc- 
tion to be fetched is present on BUS and 
the lower half of port 2. 

4. SS is then raised high to bring the pro- 
cessor out of the stopped mode allowing it 
to fetch the next instruction. The exit from 
stop is indicated by the processor bringing 
ALE low. 

5. To stop the processor at the next instruc- 
tion SS must be brought low again as soon 
as ALE goes low. If SS is left high the pro- 
cessor remains in a "Run" mode. 

A diagram for implementing the single step 
function of the 8748 is shown. A D-type flip- 
flop with preset and clear is used to generate 
SS. In the run mode SS is held high by 
keeping the flip-flop preset (preset has prec- 
edence over the clear input). To enter single 
step, preset is removed allowing ALE to bring 
SS low via the clear input. ALE should be 
buffered since the clear input of an SN7474 is 
the equivalent of 3 TTL loads. The processor 
is now in the stopped state. The next instruc- 
tion is initiated by clocking a "1" into the flip- 
flop. This "1" will not appear on SS unless 
ALE is high removing clear from the flip-flop. 
In response to SS going high the processor 
begins an instruction fetch which brings ALE 
low resetting SS through the clear input and 
causing the processor to again enter the 
stopped state. 
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SINGLE STEP CIRCUIT 



MOMENTARY 
PUSHBUTTON 



n 



SINGLE > 10K 
STEP 



D^ 




> CLOCK 



CLEAR 
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<— 



SINGLE STEP TIMING 
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\ 
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\ 



DATA 
BUS- 



< 



>" 



X 



x: 



ACTIVE CYCLE 



2.1.14 Power Down Mode 
(8048, 8049, 8039, 8035L) 

Extra circuitry has been added to the 8048 
ROM version to allow power to be removed 
from all but the 64/128 x 8 data RAM array 
for low power standby operation. In the 
power down mode the contents of data 
RAM can be maintained while drawing 
typically 10% to 15% of normal operating 
power requirements. 



Vcc serves as the 5V supply pin for the bulk 
of 8048 circuitry while the Vdd pin supplies 
only the RAM array. In normal operation both 
pins are at 5V while in standby Vcc is at 
ground and only Vdd ' s maintained at 5V. 
Applying Reset to the processor through the 
Reset pin inhibits any access to the RAM by 
the processor and guarantees that RAM can- 
not be inadvertently altered as power is 
removed from Vcc ■ 
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POWER SUPPLY 


PROCESSOR 
INTERRUPTED 

/ 


"^ 








POWER SUPPLY 
FAIL SIGNAL 






NORMAL 
POWER ON 








SEQUENCE 
FOLLOWS 


RESET 


1 






. 




1 






1 
DATA SAVE 
ROUTINE 
EXECUTED 


1 
ACCESS TO 
DATA RAM 
INHIBITED 





POWER DOWN SEQUENCE 

A typical power down sequence occurs as 
follows: 

1 . Imminent power supply failure is detected 
by user defined circuitry. Signal must be 
early enough to allow 8048 to save all nec- 
essary data before Vcc falls below normal 
operating limits. 

2. Power fail signal is used to interrupt 
processor and vector it to a power fail 
service routine. 

3. Power fail routine saves all important 
data and machine status in the internal data 
RAM array. Routine may also initiate trans- 
fer of backup supply to the Vdd pin and 
indicate to external circuitry that power fail 
routine is complete. 

4. Reset is applied to guarantee data will 
not be altered as the power supply falls out 
of limits. Reset must be held low until V cc 
is at ground level. 

Recovery from the Power Down mode can 
occur as any other power-on sequence with 
an external capacitor on the Reset input 
providing the necessary delay. See the previ- 
ous section on Reset. 

2.1.15 External Access Mode 

Normally the first 1K (8048) or 2K (8049) 
words of program memory are automati- 
cally fetched from internal ROM or EPROM. 
The EA input pin however allows the userto 



effectively disable internal program mem- 
ory by forcing all program memory fetches 
to reference external memory. The follow- 
ing chapter explains how access to external 
program memory is accomplished. 

The External Access mode is very useful in 
system test and debug because it allows the 
user to disable his internal applications pro- 
gram and substitute an external program of 
his choice — a diagnostic routine for instance. 
In addition, the section on Test and Debug 
explains how internal program memory can 
be read externally, independent of the 
processor. 

A "1" level on EA initiates the external access 
mode. For proper operation, Reset should be 
applied while the EA input is changed. 

2.2 Pin Description 

The MCS-48 processors (except 8021) are 
packaged in 40 pin Dual In-Line Packages 
(DIP's). The following is a summary of the 
functions of each pin. Where it exists, the 
second paragraph describes each pin's 
function in an expanded MCS-48 system. 
Unless otherwise specified, each input is 
TTL compatible and each output will drive 
one standard TTL load. 



PROGRAM 
PROM 



■C 



RESET- 
SINGLE STEP- 

EXTERNAL. 

MEM. 



TEST 



{=: 



INTERRUPT - 



BUS 



c 



V 



GND 



8048 
8049 



^ 



bo 



PORT 

#1 



PORT 

#2 



READ 
0-»- WRITE 



PROGRAM 
STORE ENABLE 

ADDRESS 
LATCH ENABLE 



8048 LOGIC SYMBOL 
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Designation 



Pin 
Number 



Function 



V S s 
V DD 

Vcc 
PROG 



P10-P17 
(Portl) 

P20-P27 
(Port 2) 



D0-D7 
(BUS) 



20 
26 

40 
25 

27-34 

21-24 
35-38 

12-19 



TO 

T1 

INT 
RD 



39 

6 
8 



Circuit GND potential 

Programming power supply; +25V during program, 
+ 5V during operation for both ROM and PROM. Low 
power standby pin in 8048 ROM version 

Main power supply; +5V during operation and 
8748 programming. 

Program pulse ( + 25V) input pin during 8748 
programming. 

Output strobe for 8243 I/O expander. 

8-bit quasi-bidirectional port. (Internal Pullup ~ 50KO) 

8-bit quasi-bidirectional port. (Internal Pullup ~ 50KO) 

P20-P23 contain the four high order program counter 
bits during an external program memory fetch and serve 
as a 4-bit I/O expander bus for 8243. 

True bidirectional port which can be written or read syn- 
chronously using the RD, WR strobes. The port can also 
be statically latched. 

Contains the 8 low order program counter bits during an 
external program memory fetch, and receives the ad- 
dressed instruction under the control of PSEN. Also con- 
tains the address and data during an external R AM d ata 
store instruction, under control of ALE, RD, and WR. 

Input pin testable using the conditional transfer instruc- 
tions JTO and JNTO. TO can be designated as a clock 
output using ENTO CLK instruction. TO is also used dur- 
ing programming. 

Input pin testable using the JT1, and JNT1 instructions. 
Can be designated the event counter input using the 
STRT CNT instruction. 

Interrupt input. Initiates an interrupt if interrupt is enabled. 
Interrupt is disabled after a reset. (Active low) 

Output strobe activated during a BUS read. Can be 
used to enable data onto the BUS from an external 
device. (Active low) 
Used as a Read Strobe to External Data Memory. 
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Designation 



Pin 
Number 



Function 



RESET 

WR 
ALE 

PSEN 
SS 

EA 



10 



11 



XTAL1 



Input which is used to initialize the processor. Also used 
during PROM programming and verification. (Active low) 
(Internal pullup « 200KH) 

Output strobe during a BUS write. (Active low) 
Used as write strobe to external data memory. 

Address Latch Enable. This signal occurs once during 
each cycle and is useful as a clock output. 

The negative edge of ALE strobes address into external 
data and program memory. 

Program Store Enable. This output occurs only during a 
fetch to external program memory. (Active Low) 

Single step input can be used in conjunction with ALE 
to "single step" the processor through each instruction. 
(Active Low) (Internal pullup - 300KH) 

External Access input which forces all program memory 
fetches to reference external memory. Useful for emula- 
tion and debug, and essential for testing and program 
verification. (Active High) (Internal pullup « 10MO 
on 8048/8049, 8035L, 8039 only) 

One side of crystal input for internal oscillator. Also input 
for external source. 

Other side of crystal input. 



XTAL2 

Unless otherwise stated inputs do not have internal pullup resistors. 

2.3 Programming, Verifying and 
Erasing EPROM 

The internal Program Memory of the 8748 
may be erased and reprogrammed by the user 
as explained in the following sections: 

2.3.1 Programming/Verification 

In brief, the programming process consists 
of: activating the program mode, applying an 
address, latching the address, applying data, 
and applying a programming pulse. Each 
word is programmed completely before moving 
on to the next and is followed by a verifica- 
tion step. The following is a list of the pins 
used for programming and a description of 
their functions: 



Pin 


Function 


XTAL1 


Clock Input (1 to 6MHz) 


Reset 


Initialization and Address 
Latching 


TestO 


Selection of Program or 
Verify Mode 


EA 


Activation of Program/Verify 
Modes 


BUS 


Address and Data Input 
Data Output During Verify 


P20-1 


Address Input 


Vdd 


Programming Power Supply 


PROG 


Program Pulse Input 
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+5V 



TEST 




+25V 
+5V ■ 



BUS AND PROG CAN BE DRIVEN ONLY DURING THIS TIME 



BUS 



< 



ADDRESS A -A 7 



X 



) — c 



PREVIOUS 
ADDRESS 



X 



ADDRESS A 8 -Ag 



V D D 



PROG +ov — 



FLOAT 



+25V 



y~ 



FLOAT 



SEE 8048/8748 DATA SHEET (CHAPTER 6) FOR DETAIL TIMING SPECIFICATIONS. 



WARNING: An attempt to program a mis-socketed 8748 will result in severe damage to the part. An indication of a properly socketed part 
is the appearance of the ALE clock output. The lack of this clock may be used to disable the programmer. 



PROGRAMMING/VERIFY SEQUENCE 



8748 Erasure Characteristics 

The erasure characteristics of the 8748 are 
such that erasure begins to occur when 
exposed to light with wavelengths shorter 
than approximately 4000 Angstroms (A). It 
should be noted that sunlight and certain 
types of fluorescent lamps have wave- 
lengths in the 3000-4000A range. Data 
show that constant exposure to room level 
fluorescent lighting could erase the typical 
8748 in approximately 3 years while it 
would take approximately 1 week to cause 
erasure when exposed to direct sunlight. If 
the 8748 is to be exposed to these types of 
lighting conditions for extended periods of 
time, opaque labels are available from Intel 
which should be placed over the 8748 win- 
dow to prevent unintentional erasure. 



When erased, bits of the 8748 Program 
Memory are in the logic "0" state. 



The recommended erasure procedure for 
the 8748 is exposure to shortwave ultra- 
violet light which has a wavelength of 2537 
Angstroms (A). The integrated dose (i.e., UV 
intensity X exposure time) for erasure 
should be a minimum of 15W-sec/cm2. The 
erasure time with this dosage is approxi- 
mately 15 to 20 minutes using an ultraviolet 
lamp with a 12000/iW/cm2 power rating. 
The 8748 should be placed within one inch 
from the lamp tubes during erasure. Some 
lamps have a filter on their tubes and this 
filter should be removed before erasure. 
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The Program/Verify sequence is: 

1. Vdd = 5v, Clock applied or internal 
oscillator operating, Reset = Ov Test = 
5v, EA = 5v, BUS and PROG floating 

2. Insert 8748 in programming socket 

3. Test = Ov (Select Program Mode) 

4. EA = 25v (Activate Program Mode) 

5. Address applied to BUS and P20-1 

6. Reset = 5v (Latch Address) 

7. Data applied to BUS 

8. Vdd = 25v (Programming Power) 

9. PROG = Ov followed by one 50ms pulse 
to25v 

10. V DD = 5v 

11. TEST = 5v (Verify Mode) 

12. Read and Verify Data on BUS 

13. TEST = Ov 



14. Reset = Ov and repeat from Step 5 

15. Programmer should be at conditions of 
Step 1 when 8748 is removed from socket. 



2.4 Test and Debug 

Several MCS-48 features described in the 
previous sections are discussed here to 
emphasize their use in testing MCS-48 
components and in debugging MCS-48 
based systems. 

2.4.1 Single Step 

Single step circuitry within the micro- 
computer in combination with the external 
circuitry described in Section 2.1.13 allows 
the user to execute one instruction at a time 
whether the instruction is one or two cycles 
in length. After completion of the instruction 
the processor halts with the address of the 
next instruction to be fetched available on the 
eight lines of BUS and the lower 4-bits of port 
2. 



P23 
P22 
P21 
P20 
DB7 
DB6 
DB5 
DB4 
DB3 
DB2 
DB1 
DBO 



An 
Aio 
A 9 
A 8 
A 7 
A 6 
A 5 
A 4 
A 3 
A 2 

A 1 
A„ 



ADDRESS OUTPUT DURING SINGLE STEP 

This allows the user to step through his 
program and note the sequence of instruc- 
tions being executed. 

While the processor is stopped, the I/O 
information on BUS and the 4-bits of port 2 is, 
of course, not available. I/O information is, 
however, valid at the leading edge of ALE and 
can be latched externally using this signal if 
necessary. 

2.4.2 Disabling Internal Program Memory 

Applying +5V to the EA (external access) pin 
of the MCS-48 microcomputers allows the 
user to effectively disable internal program 
memory by forcing all instruction fetches to 
occur from an external memory. This 
external memory can be connected as 
explained in the section on program memory 
expansion and can contain a diagnostic 
routine to exercise the processor, the internal 
RAM, the timer, and the I/O lines. EA should 
be switched only when the processor is in 
RESET. 

2.4.3 Reading Internal Program Memory 

Just as the processor may be isolated from 
internal program memory using EA, program 
memory can be read independent of the 
processor using the verification mode des- 
cribed in the previous section, Programming/ 
Verification. 
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The processor is placed in the READ mode 
by applying a high voltage (+25V for the 
8748, +1 2V for the 8048/8049) to the EA pin 
and +5V to the TO (8748 only) input pin. 
RESET must be at 0V when voltage is 
applied to EA. The address of the location 
to be read is then applied to the same lines 



(TTL levels) of BUS and Port 2 which output 
the address during single step (see below). 
The address is latched by a "0" to "1" 
transition on RESET and a high level on 
RESET causes the contents of the program 
memory location addressed to appear on 
the eight lines of BUS. 
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8021 Functional Specifications 

The following is a functional description of 
the major elements of the 8021. 

2.5 Program Memory 

The 8021 contains 1K x 8 of mask 
programmable ROM. No external ROM 
expansion capability is provided. 

2.6 Data Memory 

A 64 x 8 dynamic RAM is located on chip for 
data storage. All locations are indirectly 
addressable and eight designated locations 
are directly addressable. Also, included in 
the memory is the address stack, addressed 
by a 3-bit stack pointer. 

Memory is organized as shown in Figure 1. 
The least significant 8 addresses, 0-7, are 
directly addressable by any of the 1 1 direct 
register instructions. The locations are 
readily accessible for a variety of opera- 
tions with the least number of instruction 
bytes required for their manipulation. 

Registers and 1 have another function, in 
that they can be used to indirectly address 
all locations in memory, using the indirect 
register instructions. These indirect RAM 
address registers, IRAR's, are especially 
useful for repetitive-type operations on 
adjacent memory locations. The indirect 
register instruction specifies which IRAR to 
use, and the contents of the IRAR is used to 
address a location in RAM. The contents of 
the addressed location is used during the 
execution of the instruction and may be 
modified. A value larger than 63 should not 
be preset in the IRAR when selected by an 
indirect register instruction. IRAR's may 
point to address 0-7, if desired. 

Locations 8-23 may be used as the address 
stack. The address stack enables the 
processor to keep track of the return 
addresses generated from CALL instruc- 
tions. A 3-bit stack pointer (SP) supplies the 
address of the locations to be loaded with 



the next return address generated. The SP 
to this pushdown stack is incremented by 
one after a return address is stored, and 
decremented by one before an address is 
fetched during a RET. A total of 8 levels of 
nesting is possible. The SP is initialized to 
location 8 upon RESET. Since each 
address is 10-bits long, two bytes must be 
used to store a single address. The SP is 
incremented and decremented by one, but 
each increment or decrement moves the 
address pointed to by two. Therefore, only 
even numbered addresses are pointed to. 

If a particular application does not require 8 
levels of nesting, the unused portion of the 
stack may be used as any other indirectly 
addressable scratchpad location. For ex- 
ample, if only 3 levels of subroutine nesting 
are used, then only locations 8-13 need be 
reserved for the address stack, and 
locations 14-63 can be used for data 
storage. The unincremented program 
counter address is stored in the address 
stack. The stack contents is incremented 
before being loaded into the program 
counter during a return from subroutine. 



INDIRECTLY 

ADDRESSABLE 

BY 

IRAR0OR1 



CAN BE USED 
FOR ADDRESS 
STACK 



DIRECTLY 
ADDRESSABLE 



FIGURE 1. INTERNAL RAM ORGANIZATION 
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2.7 Oscillator and Clock 

The 8021 contains its own onboard 
oscillator and clock circuit, requiring only 
an external timing control element. This 
control element can be a crystal, inductor, 
resistor, or clock in. The capacitor normally 
required in resistor or inductor timing 
control operation is integrated onto the 
8021 . All internal time slots are derived from 
the external element, and all outputs are a 
function of the oscillator frequency. Pins 
XTAL1 and XTAL2 are used to input the 
particular control element. An instruction 
cycle consists of 10 states, and each state is 
a time slot of 3 oscillator periods. (See 
Figure 2) Therefore, to obtain a 10 /usee 
instruction cycle, a 3 MHz crystal should be 
used. An oscillator frequency of 3 MHz may 
also be obtained by connecting a 10KH 
resistor between XTAL1 and XTAL2. Note 
that the required resistance may vary from 
10KQ, and should be adjusted as neces- 
sary. 



The 8021 utilizes dynamic RAM and certain 
other dynamic logic. Due to the clocking 
required with dynamic circuits, the oscil- 
lator frequency must be equal to or greater 
than 600K Hz, or improper operation may 
occur. 

2.8 Timer/Event Counter 

The 8021 has internal timer/event counter 
circuits that can monitor elapsed time or 
count external events that occur during 
program execution. The circuit has an 8-bit 
binary up-counter that is presettable and 
readable with two MOV instructions. These 
instructions transfer the contents of the 
accumulator to the counter and vice-versa. 
The counter content is not affected by 
Reset, and is initialized solely by the MOV 
T,A instruction. The counter is stopped by a 
RESET or STOP TCNT instruction and 
remains stopped until started as a timer by a 
STRT T instruction or as an event counter 
by a STRT CNT instruction. Once started, 



CYCLE 

TIMES I ' I 



1 , 2 3,4, 5,6 | 7 1 8 1 9 1 10|T 1 2,3 ) 4 | S,6 [ 7 | 8 | 9,10 



X 



\/ DATA \/ 
_A ' N /I- 



ALL PORTS FOR IN AND OUTL INSTRUCTIONS 



FIGURE 2. 8021 TIMING DIAGRAM 
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the counter increments to its maximum 
count (FF), and overflows to zero. The count 
continues until stopped by a STOP TCNT 
instruction or RESET. The increment from 
maximum count to zero (overflow) sets an 
overflow flag. The state of the overflow flag 
is testable with the conditional jump in- 
struction JTF. The flag is reset by JTF or by 
executing a RESET. 

By a MOV T,A instruction, the contents of 
the accumulator are loaded to the timer. At 
the STRT T command an internal prescaler 
is zeroed and thereafter increments once 
each 30 input clocks (once each single 
cycle instruction, twice each double cycle 
instruction). The prescaler is a divide by 32. 
At the (1 11 1 1 ) to (00000) transition the timer 
is incremented. The timer is 8-bits and an 
overflow (FFH) to (00H) timer flag is set. A 
conditional branch instruction (JTF) is 
available for testing this flag, the flag being 
reset each test. Total count capacity for the 
timer is 28 x 25 = 8192 or 81 .9 msec at a 10 
jusec cycle time. Contents of the timer are 
moved to the accumulator by the MOV A,T 
instruction without disturbing the counting 
process. The timer stops upon the STOP 
TCNT instruction. 

The STRT CNT instruction connects the T1 
input pin to the event counter input and 
enables the counter. Subsequent high-to- 
low transitions on T1 increment the 
counter. The maximum rate at which the 
counter can increment is once per three 
instruction cycies (30/us for a 3 MHz 
oscillator). There is no minimum frequency. 
T1 input must remain high for at least 500ns 
after each transition. The event counter is 
stopped by a STOP TCNT instruction. 

2.9 Input/Output Capabilities 

The 8021 I/O configurations are highly 
flexible. A number of different configur- 
ations are possible, tailoring an 8021 to a 
given task. Other than the power supply 
and dedicated pins, all other pins (20) can 
be used for input, output, or both, 
depending on the configuration. 

All ports are quasi-bidirectional to facili 
tate stand-alone use. A simplified sche- 



matic of the quasi-bidirectional inter- 
face is shown in Figure 3. This con- 
figuration allows buffered outputs, and 
also allows external input. Data written to 
these ports is statically latched and remains 
unchanged until rewritten. As input ports 
these lines are non-latching, i.e., inputs 
must be present until read by an input 
instruction. When writing a "0" or low value 
to these ports, the large pulldown device 
sinks an external TTL load. When writing a 
"1", a large current is supplied through the 
large pullup device to allow a fast data 
transfer. After a short time (less than one 
instruction cycle), the large device is shut 
off and the small pullup maintains the "1" 
level indefinitely. However, in this situation, 
an input device capable of overriding the 
small amount of sustaining current sup- 
plied by the pullup device can be read. 
(Alternatively, the data written can be read). 
So, by writing a "1" to any particular pin, 
that pin can serve either as a true high-level 
latched output pin, or as just a pullup 
resistor on an input. This allows maximum 
user flexibility in selecting his input or 
latched output pins, with a minimum of 
external components. 

Port 00-07 is also quasi-bidirectional, 
except there is no large pullup device. As 
outputs, this port is essentially open drain. 

By mask option the small pullup devices on 
P00-P07 may be deleted on any pin 
providing a true open drain output. This is 
useful in driving analog circuits and certain 
loads, such as keyboards. 




INPUT BUFFER 



FIGURE 3. QUASI-BIDIRECTIONAL 
PORT STRUCTURE 
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2.9.1 T1 Input 

The 8021 T1 input line can be used as an 
input for the following functions: 

• Event Counter (external input) 

• Test input for branch instructions 

• Zero voltage crossing detection 

The operation of T1 as an input to the Event 
Counter is described in the Timer/Event 
Counter section. When used as a test input, 
theJTI andJNTI instructions test fori and 
levels, respectively. 

The T1 pin can also be used to detect the 
zero crossing of slowly moving AC signals 
(60 Hz). The self-biasing circuit shown in 
Figure 4 permits the Test 1 input to detect 
when the input voltage crosses zero within 
±5%, then the voltage is coupled through 
a "1.0/xf capacitor. Maximum input voltage is 
3V peak-to-peak. The zero cross detection 
is especially useful in SCR control of 60 Hz 
power and in developing time-of-day and 
other timing routines. As a ROM mask 
option there is a pullup resistor that is 
useful for switch contact input or standard 
TTL. 

2.9.2 High Current Outputs 

Very high current drive is desirable for 



(a) ZERO CROSS DETECT 



EXTERNAL 
CAPACITOR 



>>->- 



minimizing external parts required to do 
high power control. P10 and P1 1 have been 
designated high drive outputs capable of 
sinking 7mA at Vss + 2.5 volts. (For clarity, 
this is 7mA to Vss with a 2.5 volt drop across 
the buffer.) These pins may, of course, be 
paralleled for 14mA drive if the output logic 
states are always the same. 

2.9.3 Expanded I/O 

The 8021 can be used with the 8243 I/O 
expander chip, which provides additional 
I/O capability with a limited number of 
overhead pins. This chip has 4 directly 
addressable 4-bit ports. It connects to the 
PROG pin, which providesa clock, and pins 
P20-P23, which provide address and data. 
These ports can be written with a MOVD 
P,A; ANLD P,A; and ORLD P,A for Ports 4-7. 
A high to low transition on PROG signifies 
that address and control are available on 
P20-P23. The previous data on P20-P23 
before an output expander instruction is 
lost. Therefore, when using an output 
expander P20-P23 are not useful for 
general input/output. Reading is via the 
MOVD A, P. This circuit configuration is 
shown in Figure 5. The timing diagram is 
shown in Figure 6. 

The 8021 can also use standard low cost 
TTL to expand the number of I/O lines. An 
example is shown in the Applications 
section. 
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FIGURE 4. TEST 1 PIN 



FIGURE 5. I/O EXPANDER INTERFACE 
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FIGURE 6. EXPANDED I/O TIMING DIAGRAM 



2.10 CPU 

The 8021 CPU has arithmetic and logical 
capability. A wide variety of arithmetic and 
logic instructions may be exercised, which 
affect the contents of the accumulator, 
and/or direct or indirect scratchpad loca- 
tions. Provisions have been made for 
simplified BCD arithmetic capability using 
the DAA, SWAP A, and XCHD instructions. 
In addition, MOVP A,@A allows table 
lookup for display formating and constants. 
The conditional branch logic within the 
processor enables several conditions inter- 
nal and external to the processor to be 
tested by the users program. Use the 
conditional jump instructions with the tests 
listed below to effect a change in the 
program execution sequence. 



Test 



Jump Jump 

Condition Instructions 



Accumulator A=0 A*0 JZ JNZ 

Carry Flag 1 JNC, JC 

Timer Overflow Flag — 1 JTF 

Test lnput-T1 1 JNT1, JT1 



2.11 Reset 

A positive-going signal to the RESET input 
resets the necessary miscellaneous flip- 
flops and sets the program counter and 
stack pointer to zero. 



The 8021 may see poorly regulated and 
noisy power supplies. A useful feature is to 
sense when the power supply dips and do a 
RESET to prevent continued operation with 
incorrect data. This feature may be 
implemented on the 8021 by connecting a 
diode between the RESET node and 
ground. See Figure 7. 

A RESET will then be forced if the supply 
drops approximately 1.5 volts and rapidly 
recovers. One instruction cycle will RESET 
the 8021 to the initialized state. 

By removing the diode and using only the 
capacitor, voltage drops in Vcc will not 
cause a RESET. 



vcc 




FIGURE 7. POWER ON RESET 
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3.0 Summary 

If the capabilities resident on the single- 
chip 8048/8049, 8748, or 8035/8039 are not 
sufficient for your system requirements, 
special on-board circuitry allows the 
addition of a wide variety external memory, 
I/O, or special peripherals you may require. 
The processors can be directly and simply 
expanded in the following areas: 

• Program Memory to 4K words 

° Data Memory to 320 words (384 words 
with 8049) 

• I/O by unlimited amount 

• Special Functions using 8080/8085 
peripherals 

By using bank switching techniques maxi- 
mum capability is essentially unlimited. Bank 
switching is discussed later in the chapter. 
Expansion is accomplished in two ways: 

1. Expander I/O — A special I/O Expander 
circuit the 8243 provides for the addition of 
four 4-bit Input/Output ports with the sac- 
rifice of only the lower half (4 bits) of port 2 
for inter-device communication. Multiple 
8243's may be added to this 4-bit bus by 
generating the required "chip select" lines. 

2. Standard 8085 Bus— One port of the 
8048 is like the 8 bit bidirectional data bus 
of the 8085 microcomputer system allow- 
ing interface to the numerous standard 
memories and peripherals of the MCS- 
80/85 microcomputer family. 

MCS-48 systems can be configured using 
either or both of these expansion features to 
optimize system capabilities to the application. 
Both expander devices and standard mem- 
ories and peripherals can be added in virtually 
any number and combination required. 



3.1 Expansion of Program Memory 

Program Memory is expanded beyond the 
resident 1K or 2K words by using the 8085 
BUS feature of the MCS-48. All program 
memory fetches from addresses less than 
1024 (2048) occur internally with no 
external signals being generated (except 
ALE which is always present). At address 
1024 the 8048 automatically initiates exter- 
nal program memory fetches. 

3.1.1 Instruction Fetch Cycle (External) 

For all instruction fetches from addresses 
of 1024 (2048) or greater the following will 
occur: 

1. The contents of the 12 bit program 
counter will be output on BUS and the lower 
half of port 2. 

2. Address Latch Enable (ALE) will indi- 
cate the time at which address is valid. The 
trailing edge of ALE is used to latch the 
address externally. 



3. Program Store Enable (PSEN) indicates 
that an external instruction fetch is in prog- 
ress and serves to enable the external 
memory device. 

4. BUS reverts to input (floating) mode 
and the processor accepts its 8 bit 
contents as an instruction word. 

All instruction fetches including internal 
addresses can be forced to be external by 
activating the EA pin of the 8048/8049. The 
8035/8039 processors without program 
memory always operate in the external 
program memory mode (EA=5V). 

3.1.2 Extended Program Memory 
Addressing (Beyond 2K) 

For programs of 2K words or less, the 
8048/8049 addresses program memory in 
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EXTERNAL PROGRAM MEMORY 

the conventional manner. Addresses be- 
yond 2047 can be reached by executing a 
program memory bank switch instruction 
(SEL MBO, SEL MB1) followed by a branch 
instruction (JMP or CALL). The bank switch 
feature extends the range of branch 
instructions beyond their normal 2K range 
and at the same time prevents the user from 
inadvertently crossing the 2K boundary. 

Program Memory Bank Switch 

The switching of 2K program memory banks 
is accomplished by directly setting or resetting 
the most significant bit of the program counter 
(bit 11). Bit 11 is not altered by normal incre- 
menting of the program counter but is loaded 
with the contents of a special flip-flop each 
time a JMP or CALL instruction is executed. 
This special flip-flop is set by executing an 
SELMB1 instruction and reset by SEL MBO. 
Therefore, the SEL MB instruction may be 
executed at any time prior to the actual bank 
switch which occurs during the next branch 
instruction encountered. Since all twelve bits 
of the program counter including bit (11) are 
stored in the stack when a Call is executed, 
the user may jump to subroutines across the 
2K boundary and the proper bank will be 
restored upon return. However, the bank 
switch flipflop will not be altered on return. 

Interrupt Routines 

Interrupts always vector the program counter 
to location 3 or 7 in the first 2K bank and bit 
11 of the program counter is held at "0" 
during the interrupt service routine. The end 
of the service routine is signalled by the 
execution of an RETR instruction. Interrupt 
service routines should therefore be contained 



Conventional Program Counter 

• Counts 000H to 7FFH 

• Overflows 7FFH to 000H 

JMP or CALL instructions transfer contents of 
internal flipflop to An 

• Flipflop set by SEL MB1 

• Flipflop reset by SEL MBO 
or by RESET 

During interrupt service routine 

A11 is forced to "0" 

All 12 bits are saved in stack 



PROGRAM COUNTER 

entirely in the lower 2K words of program 
memory. The execution of a SEL MBO or SEL 
MB1 instruction within an interrupt routine is 
not recommended since it will not alter PC11 
while in the routine, but will change the 
internal flip flop. 

3.1.3 Restoring I/O Port Information 

Although the lower half of Port 2 is used to 
output the four most significant bits of address 
during an external program memory fetch, 
the I/O information is still outputed during 
certain portions of each machine cycle. I/O 
information is always present on Port 2 lower 
at the rising edge of ALE and can be sampled 
or latched at this time. 

3.1.4 Expansion Examples 

The accompanying figure shows the addition 
of three 2708 1K X 8 EPROMs or three 8308 
pin-compatible ROM replacements for a total 
of 4K words of program memory. The BUS 
port of the 8048 is connected directly to the 
data output lines of the memories. The lower 
8 bits of address are latched in an 8212 8-bit 
latch using ALE as the strobe. The lower half 
of Port 2 provides the upper 4 bits of address 
and since these address bits are stable for 
the duration of the program memory fetch, 
they do not have to be latched. Two of the 
upper address bits are connected directly to 
the address inputs of the memories while the 
two most significant bits are decoded to 
provide the three chip selects needed. The 
PSEN output of the 8048/8748 is used to 
enable the chip select lines and therefore the 
memories. 
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Also shown is the addition of 2K words of 
program memory using an 831 6A 2K x 8 
ROM to give a total of 3K words of program 
memory. In this case n o chip select decoding 
is required and PSEN enables the memory 
directly through the chip select input. If the 
system requires only 2K of program the same 
configuration can be used with an 8035 
substituted for the 8048. The 8049 would 
provide 4K with the same configuration. 



The next figure shows how the new 8755/8355 
EPROM/ROM with I/O interfaces directly to 
the 8048 without the need for an address 
latch. The 8755/8355 contains an internal 8-bit 
address latch eliminating the need for an 
8212 latch. In addition to a 2K X 8 program 
memory the 8755/8355 also contains 16 I/O 
lines addressable as two 8-bit ports. These 
ports are addressed as external RAM; there- 
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fore, the RD and WR outputs of the 8048 are 
required. See the following section on data 
memory expansion for more detail. The sub- 
sequent section on I/O expansion explains 
the operation of the 16 I/O lines. 
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3.2 Expansion of Data Memory 

Data Memory is expanded beyond the resi 
dent 64 words by using the 8085 type bus 
feature of the MCS-48. 

3.2.1 Read/Write Cycle 

All address and data is transferred over the 8 
lines of BUS. A read or write cycle occurs as 
follows: 

1. The contents of register R0 or R1 is out- 
puted on BUS. 

2. Address Latch Enable (ALE) indicates 
address is valid. The trailing edge of ALE is 
used to latch the address externally. 

3. A read (RD) or write (WR) pulse on the 
corresponding output pins of the 8048 indi- 
cates the type of data memory access in 
progress. Output data is valid at the trailing 
edge of WR and inputdata must be valid at 
the trailing edge of RD. 

4. Data (8-bits) is transferred in or out over 
BUS. 
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3.2.2 Addressing External Data Memory 

External Data Memory is accessed with its 
own two-cycle move instructions MOVX A, 
@R and MOVX @R, A which transfer 8 bits of 
data between the accumulator and the ex- 
ternal memory location addressed by the 
contents of one of the RAM Pointer Registers 
RO or R1. This allows 256 locations to be 
addressed in addition to the resident 
locations. Additional pages may be added 
by "bank switching" with extra output lines of 
the 8048. 

3.2.3 Examples of Data Memory 
Expansion 

The accompanying figure shows how the 
8048 can be expanded using standard 256 X 
4 static RAMs such as the 2101-2 or its low 
power CMOS equivalent, the 5101. An 8212 
serves as an address latch while each 4-bit 
half of BUS is connected directly to a bidirec- 



tional 4-bit data bus of the memories. The WR 
output of the processor controls the Read/ 
Write input of the memories while the data 
bus output_drivers of the memories are con- 
trolled by RD. The chip select lines of the 
memories are continuously enabled unless 
additional pages of RAM are required. Also 
shown is the expansion of data memory using 
the 8155 memory and I/O expanding device. 
Since the 8155 has an internal 8-bit address 
latch it can interface directly to the 8048 with- 
out the use of an external 8212 latch. The 
8155 provides an additional 256 words of sta- 
tic data memory and also includes 22 I/O 
lines and a 14 bit timer. See the following sec- 
tion on I/O expansion and the 8155 data sheet 
for more details on these additional features. 

3.3 Expansion of Input/Output 

There are four possible modes of I/O 
expansion with the 8048: one using a 
special low cost expander, the 8243; 
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another using standard MCS-80/85 I/O 
devices; and a third using the combination 
memory/I/O expander devices the 8155, 
8355, and 8755. It is also possibleto expand 
using standard TTL devices as shown in 
Chapter 5. 

3.3.1 I/O Expander Device 

The most efficient means of I/O expansion for 
small systems is the 8243 I/O Expander De- 
vice which requires only 4 port lines (lower 
half of Port 2) for communication with the 
8048. The 8243 contains four 4-bit I/O ports 
which serve as extension of the on chip I/O 
and are addressed as ports #4-7. The follow- 
ing operations may be performed on these 
ports: 

1. Transfer Accumulator to Port. 

2. Transfer Port to Accumulator. 

3. AND Accumulator to Port. 

4. OR Accumulator to Port. 

A 4-bit transfer from a port to the lower half of 
the Accumulator sets the most significant four 



bits to zero. All communication between the 
8048 and the 8243 occurs over Port 2 lower 
(P20-P23) with timing provided by an output 
pulse on the PROG pin of the processor. Each 
transfer consists of two 4-bit nibbles: 

The first containing the "op code" and port 
address and the second containing the actual 
4 bits of data. 
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A high to low transition of the PROG line indi- 
cates that address is present while a low to 
high transition indicates the presence of data. 
Additional 8243's may be added to the four bit 
bus and chip selected using additional output 
lines from the 8048/8748. 

I/O Port Characteristics 

Each of the four 4-bit ports of the 8243 can 
serve as either input or output and can pro- 
vide high drive capability in both the high and 
low state. 

3.3.2 I/O Expansion with Standard 
Peripherals 

Standard MCS-80/85 type I/O devices may 
be added to the MCS-48 using the same bus 
and timing used for Data Memory expan- 
sion. I/O devices reside on the Data 
Memory bus and in the data memory 
address space and are accessed with the 
same MOVX instructions. See the previous 
section on data memory expansion for a 
description of timing. The following are a 
few of the Standard MCS-80 devices which 
are very useful in MCS-48 systems. 

8214 Priority Interrupt Encoder 
8251 Serial Communications Interface 
8255 General Purpose Programmable I/O 
8279 Keyboard/Display Interface 
8253 Interval Timer 

See Chapter 7 for detailed data sheets on 
these and other components. 



3.3.3 Combination Memory and I/O 
Expanders 

As mentioned in the sections on program and 
data memory expansion the 8355/8755 and 
8155 expanders also contain I/O capability. 

8355/8755: These two parts are ROM and 
EPROM equivalents and therefore contain 
the same I/O structure. I/O consists of two 
8-bit ports which normally reside in the exter- 
nal data memory address space and are ac- 
cessed with MOVX instructions. Associated 
with each port is an 8-bit Data Direction Reg- 
ister which defines each bit in the port as 
either an input or an output. The data direction 
registers are directly addressable thereby al- 
lowing the user to define under software con- 
trol each individual bit of the ports as either 
input or output. All outputs are statically 
latched and double buffered. Inputs are not 
latched. 

8155/8156: I/O on the 8155/8156 is config- 
ured as two 8-bit programmable I/O ports 
and one 6-bit programmable port. These 
three registers and a Control/Status regis- 
ter are accessible as external data memory 
with the MOVX instructions. The contents 
of the control register determines the mode 
of the three ports. The ports can be 
programmed as input or output with or 
without associated handshake communi- 
cation lines. In the handshake mode, lines 
of the six-bit port become input and out- 
put strobes for the two 8-bit ports. See the 
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data sheet in the Chapter 6 for details. Also 
included in the 8155 is a 14-bit programmable 
timer. The clock input to the timer and the 
timer overflow output are available on exter- 
nal pins. The timer can be programmed to 
stop on terminal count or to continuously re- 
load itself. A square wave or pulse output on 
terminal count can also be specified. 

I/O Expansion Examples 
(See Also Chapter 5) 

The accompanying figure shows the expan- 
sion of I/O using multiple 8243's. The only 
difference from a single 8243 system is the 
addition of chip selects provided by additional 
8048 output lines. Two output lines and two 
inverters could also be used to address the 
four chips. Large numbers of 8243's would 
require a chip select decoder chip such as the 
8205 to save I/O pins. 

Also shown is the 8048 interface to a stan- 
dard MCS-80 peripheral; in this case, the 
8255 Programmable Peripheral Interface, a 
40 pin part which provides three 8-bit pro- 
grammable I/O ports. The 8255 bus interface 
is typical of programmable MCS-80 peripher- 
als with an 8-bit bidirectional data bus, a RD 
and WR input for Read/Write control, a CS 



(crjip select) input used to enable the Read/ 
Write control logic and the address inputs 
used to select various internal registers. 
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interconnection to the 8048 is very 
straightforward with BUS, RD, and WR con- 
necting directly to the corresponding pins on 
the 8255. The only design consideration is the 
way in which the internal registers of the 8255 
are to be addressed. If the registers are to be 
addressed as external data memory using the 
MOVX instructions, the appropriate number of 
address bits (in this case, 2) must be latched 
on BUS using ALE as described in the section 
on external data memories. If only a single 
device is connected to BUS, the 8255 may be 
continuously selected by grounding CS. If 
multiple 8255's are used, additional address 
bits can be latched and used as chip selects. 

A second addressing method eliminates ex- 
ternal latches and chip select decoders by 
using output port lines as address and chip 
select lines directly. This method, of course, 
requires the setting of an output port with ad- 
dress information prior to executing a MOVX 
instruction. 



3.4 Multi-Chip MCS-48 Systems 

The accompanying figure shows the addition 
of two memory expanders to the 8048, one 
8355/8755 ROM and one 8156 RAM. The 
main consideration in designing such a sys- 
tem is the addressing of the various memories 
and I/O ports. Note that in this configuration 
address lines A 10 and An have been ORed to 
chip select the 8355. This ensures that the 
chip is active for all external program memory 
fetches in the 1K to 3K range and is disabled 
for all other addresses. This gating has been 
added to allow the I/O port of the 8355 to be 
used. If the chip was left selected all the time 
there would be conflict between these ports 
and the RAM and I/O of the 81 56. The NOR 
gate could be eliminated and An connected 
directly to the CE (instead of CE) input of the 
8355; however, this would create a 1K word 
"hole" in the program memory by causing the 
8355 to be active in the 2K to 4K range in- 
stead of the normal 1K to 3K range. 
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In this system the various locations are ad- 
dressed as follows: 

Data RAM— Addresses to 255 when Port 
2 Bit has been previously set = 1 and Bit 1 
set = 

RAM I/O— Addresses to 3 when Port 2 
Bit = 1 and Bit 1 =1 

ROM I/O— Addresses to 3 when Port 2 
Bit 2 or Bit 3 = 1 

3.5 Memory Bank Switching 

Certain systems may require more than the 
4K words of program memory which are 
directly addressable by the program counter 
or more than the 256 data memory and I/O 
locations directly addressable by the pointer 



registers RO and R1. These systems can be 
achieved using "bank switching" techniques. 
Bank switching is merely the selection of 
various blocks or "banks" of memory using 
dedicated output port lines from the processor. 
In the case of the 8048 program memory is 
selected in blocks of 4K words at a time 
while data memory and I/O are enabled 256 
words at a time. 

The most important consideration in imple- 
menting two or more banks is the software 
required to cross the bank boundaries. Each 
crossing of the boundary requires that the 
processor first write a control bit to an output 
port before accessing memory or I/O in the 
new bank. If program memory is being 
switched, programs should be organized to 
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keep boundary crossings to a minimum. 
Jumping to subroutines across the boundary 
should be avoided when possible since the 
programmer must keep track of which bank 
to return to after completion of the subrou- 
tine. If these subroutines are to be nested and 
accessed from either bank, a software "stack" 
should be implemented to save the bank 
switch bit just as if it were another bit of the 
program counter. 

From a hardware standpoint bank switching 
is very straight-forward and involves only the 
connection of an I/O line or lines as bank 
enable signals. These enables are ANDed 
with normal memory and I/O chip select 
signals to activate the proper bank. 

3.6 Control Signal Summary 

The following table summarizes the in- 
structions which activate the various 
control outputs of the MCS-48 processors. 



CONTROL 
SIGNAL 


WHEN ACTIVE 


RD 


DURING MOVX A,@R OR INS BUS 


WR 


DURING MOVX @R,A OR OUTL BUS 


ALE 


EVERY MACHINE CYCLE 


PSEN 


DURING FETCH OF EXTERNAL 
PROGRAM MEMORYONSTRUCTION 
OR IMMEDIATE DATA) 


PROG 


DURING MOVD A,P ANLD P,A 
MOVD P,AORLDP,A 



During all other instructions these outputs 
are driven to the inactive state. 

3.7 Port Characteristics 

BUS Port Operations 

The BUS port can operate in three different 
modes: as a latched I/O port, as a bi- 



directional bus port, or as a program 
memory address output when external 
memory is used. The BUS port lines are 
either active high, active low, or high 
impedance (floating). The latched mode 
(INS, OUTL) is intended for use in the single 
chip configuration where BUS is not being 
used as an expander port. OUTL and MOVX 
instructions can be mixed if necessary. 
However, a previously latched output will 
be destroyed by executing a MOVX 
instruction and BUS will be ieft in the high 
impedance state. OUTL should never be 
used in a system with external program 
memory , since latching BUS can cause the 
next instruction, if external, to be fetched 
improperly. 

Port 2 Operations 

The lower half of Port 2 can be used in three 
different ways: as a quasi, bi-directional 
static port, as an 8243 expander port, and to 
address external program memory. In all 
cases outputs are driven low by an active 
device and driven high momentarily by an 
active device and held high by a 50KI1 
resistor to +5V. 

The port may contain latched I/O data prior 
to its use in another mode without affecting 
operation of either. If lower Port 2 (P20-3) is 
used to output address for an external 
program memory fetch the I/O information 
previously latched will be automatically 
removed temporarily while address is 
present then restored when the fetch is 
complete. However, if lower Port 2 is used 
to communicate with an 8243, previously 
latched I/O information will be removed 
and not restored. After an input from the 
8243 P20-3 will be left in the input mode 
(floating). After an output to the 8243 P20-3 
will contain the value written, ANDed, or 
ORed to the 8243 port. 
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4.0 INTRODUCTION 

The MCS-48 instruction set is extensive for 
a machine of its size and has been tailored 
to be straightforward and very efficient in 
its use of program memory. All instructions 
are either one or two bytes in length and 
over 70% are only one byte long. Also, all 
instructions execute in either one or two 
cycles (2.5jusec or 5.0jusec when using a 6 
MHz XTAL) and over 50% of all instructions 
execute in a single cycle. Double cycle 
instructions include all immediate instruc- 
tions, and all I/O instructions. 



The MCS-48 microcomputers have been 
designed to efficiently handle arithmetic 
operations in both binary and BCD as well 
as to efficiently handle the single bit 
operations required in control applications. 
Special instructions have also been in- 
cluded to simplify loop counters, table 
lookup routines, and N-way branch rou- 
tines. 

Data Transfers 

As can be seen in the accompanying 
diagram, the 8-bit accumulator is the central 
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point for all data transfers within the 8048. 
Data can be transferred between the 8 
registers of each working register bank and 
the accumulator directly, i.e. the source or 
destination register is specified by the 
instruction. The remaining locations of the 
internal RAM array are referred to as Data 
Memory and are addressed indirectly via an 
address stored in either R0 or R1 of the active 
working register bank. R0 and R1 are also 
used to indirectly address external data 
memory when it is present. Transfers to and 
from internal RAM require one cycle while 
transfers to external RAM require two. 
Constants stored in Program Memory can be 
loaded directly to the accumulator and to the 
8 working registers. Data can also be 
transfered directly between the accumulator 
and the on-board timer/counter or the 
accumulator and the Program Status word 
(PSW). Writing to the PSW alters machine 
status accordingly and provides a means of 
restoring status after an interrupt or of 
altering the stack pointer if necessary. 

Accumulator Operations 

Immediate data, data memory, or the 
working registers can be added with or 
without carry to the accumulator. These 
sources can also be ANDed, ORed, or 
Exclusive ORed to the accumulator. Data 
may be moved to or from the accumulator 
and working registers or data memory. The 
two values can also be exchanged in a single 
operation. 

In addition, the lower 4 bits of the 
accumulator can be exchanged with the 
lower 4-bits of any of the internal RAM 
locations. This instruction, along with an 
instruction which swaps the upper and lower 
4-bit halves of the accumulator, provides for 
easy handling of 4-bit quantities, including 
BCD numbers. To facilitate BCD arithmetic, 
a Decimal Adjust instruction is included. This 
instruction is used to correct the result of the 
binary addition of two two-digit BCD 
numbers. Performing a decimal adjust on the 
result in the accumulator produces the 
required BCD result. 



Finally, the accumulator can be: incre- 
mented, decremented, cleared, or comple- 
mented and can be rotated left or right 1-bit at 
a time with or without carry. 

Although there is no subtract instruction in 
the 8048, this operation can be easily 
implemented with three single-byte single- 
cycle instructions. 

A value may be subtracted from the 
accumulator with the result in the accumu- 
lator by: 

Complementing the accumulator 
Adding the value to the accumulator 
Complementing the accumulator. 

Register Operations 

The working registers can be accessed via 
the accumulator as explained above, or can 
be loaded immediate with constraints from 
program memory. In addition, they can be 
incremented or decremented or used as loop 
counters using the decrement and skip, if not 
zero instruction, as explained under branch 
instructions. 

All Data Memory including working registers 
can be accessed with indirect instructions via 
R0 and R1 and can be incremented. 

Flags 

There are four user accessible flags in the 
8048: Carry, Auxiliary Carry, F0, and F1. 
Carry indicates overflow of the accumulator, 
and Auxiliary Carry is used to indicate 
overflow between BCD digits and is used 
during decimal adjust operation. Both Carry 
and Auxiliary Carry are accessible as part of 
the program status word and are stored on 
the stack during subroutines. F0 and F1 are 
undedicated general purpose flags to be 
used as the programmer desires. Both flags 
can be cleared or complemented and tested 
by conditional jump instructions. F0 is also 
accessible via the Program Status word and 
is stored on the stack with the carry flags. 

Branch Instructions 

The unconditional jump instruction is two 
bytes and allows jumps anywhere in the first 
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2K words of program memory. Jumps to the 
second 2K of memory (4K words are directly 
addressible) are made by first executing a 
select memory bank instruction then execu- 
ting the jump instruction. The 2K boundary 
can only be crossed via a jump or subroutine 
call instruction i.e. the bank switch does not 
occur until a jump is executed. Once a 
memory bank has been selected all subse- 
quent jumps will be to the selected bank until 
another select memory bank instruction is 
executed. A subroutine in the opposite bank 
can be accessed by a select memory bank 
instruction followed by a call instruction. 
Upon completion of the subroutine execu- 
tion will automatically return to the original 
bank; however, unless the original bank is 
reselected, the next jump instruction en- 
countered will again transfer execution to the 
opposite bank. 

Conditional jumps can test the following 
inputs and machine status: 

TO Input pin 
T1_ Input pin 
INT Input pin 
Accumulator Zero 
Any bit of Accumulator 
Carry Flag 
FO Flag 
F1 Flag 

Conditional jumps allow a branch to any 
address within the current page (256 words) 
of execution. The conditions tested are the 
instantaneous values at the time the condi- 
tional jump is executed. For instance, the 
jump on accumulator zero instruction tests 
the accumulator itself not an intermediate 
zero flag. 

The decrement register and skip if not zero 
instruction combines a decrement and a 
branch instruction to create an instruction 
very useful in implementing a loop counter. 
This instruction can designate any one of the 
8 working registers as a counter and can 
effect a branch to any address within the 
current page of execution. 

A single byte indirect jump instruction allows 
the program to be vectored to any one of 



several different locations based on the 
contents of the accumulator. The contents of 
the accumulator points to a location in 
program memory which contains the jump 
address. The 8-bit jump address refers to the 
current page of execution. This instruction 
could be used, for instance, to vector to any 
one of several routines based on an ASCII 
character which has been loaded in the 
accumulator. In this way ASCII key inputs 
can be used to initiate various routines. 

Subroutines 

Subroutines are entered by executing a call 
instruction. Calls can be made like uncondi- 
tional jumps to any address in a 2K word 
bank and jumps across the 2K boundary are 
executed in the same manner. Two separate 
return instructions determine whether or not 
status (upper 4-bits of PSW) is restored upon 
return from the subroutine. 

The return and restore status instruction also 
signals the end of an interrupt service routine 
if one has been in progress. 

Timer Instructions 

The 8-bit on board timer/counter can be 
loaded or read via the accumulator while the 
counter is stopped or while counting. The 
counter can be started as a timer with an 
internal clock source or as an event counter 
or timer with an external clock applied to the 
T1 input pin. The instruction executed 
determines which clock source is used. A 
single instruction stops the counter whether 
it is operating with an internal or an external 
clock source. In addition, two instructions 
allow the timer interrupt to be enabled or 
disabled. 

Control Instructions 

Two instructions allow the external interrupt 
source to be enabled or disabled. Interrupts 
are initially disabled and are automatically 
disabled while an interrupt service routine is 
in progress and re-enabled afterward. 

There are four memory bank select instruc- 
tions, two to designate the active working 
register bank and two to control program 
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memory banks. The operation of the program 
memory bank switch is explained in section 
3.1.2. The working register bank switch 
instructions allow the programmer to imme- 
diately substitute a second 8 register working 
register bank for the one in use. This 
effectively provides 16 working registers or it 
can be used as a means of quickly saving the 
contents of the registers in response to an 
interrupt. The user has the option to switch or 
not to switch banks on interrupt. However, if 
the banks are switched, the original bank will 
be automatically restored upon execution of 
a return and restore status instruction at the 
end of the interrupt service routine. 

A special instruction enables an internal 
clock, which is the XTAL frequency divided 
by three, to be output on pin TO. This clock 
can be used as a general purpose clock in the 
users system. This instruction should be 
used only to initialize the system since the 
clock output can be disabled only by 
application of system reset. 

Input/Output Instructions 

Ports 1 and 2 are 8-bit static I/O ports which 
can be loaded to and from the accumulator. 
Outputs are statically latched but inputs are 
not latched and must be read while inputs are 
present. In addition, immediate data from 
program memory can be ANDed or ORed 
directly to Port 1 and Port 2 with the result 
remaining on the port. This allows "masks" 
stored in program memory to selectively set 
or reset individual bits of the I/O ports. Ports 1 
and 2 are configured to allow input on a given 
pin by first writing a "1" out to the pin. 

An 8-bit port called BUS can also be 
accessed via the accumulator and can have 
statically latched outputs as well. It too can 
have immediate data ANDed or ORed 
directly to its outputs, however, unlike ports 1 
and 2, all eight lines of BUS must be treated 
as either input or output at any one time. In 
addition to being a static port, BUS can be 
used as a true synchronous bi-directional 
port using the Move External instructions 
used to access external data memory. When 
these instructions are executed a cor- 



responding READ or WRITE pulse is 
generated and data is valid only at that time. 
When data is not being transferred BUS is in 
a high impedance state. 

The basic three on board I/O ports can be 
expanded via a 4-bit expander bus using half 
of port 2. I/O expander devices on this bus 
consist of four 4-bit ports which are 
addressed as ports 4 through 7. These ports 
have their own AND and OR instructions like 
the on board ports as well as move 
instructions to transfer data in or out. The 
expander AND and OR instructions, how- 
ever, combine the contents of accumu- 
lator with the selected port rather than 
immediate data as is done with the on board 
ports. 

I/O devices can also be added externally 
using the BUS port as the expansion bus. In 
this case the I/O ports become "memory 
mapped", i.e. they are addressed in the same 
way as external data memory and exist in the 
external data memory address space ad- 
dressed by pointer register RO or R1. 

4.1 Instruction Set Description 

The following pages describe the MCS-48 
instruction set in detail. The instruction set is 
first summarized with instructions grouped 
functionally. This summary page is followed 
by a detailed description listed alphabetically 
by mnemonic opcode. 

The alphabetical listing includes the follow- 
ing information: 

Mnemonic 
Machine Code 
Verbal Description 
Symbolic Description 
Assembly Language Example 

The machine code is represented with the 
most significant bit (7) to the left and two byte 
instructions are represented with the first 
byte on the left. The assembly language 
examples are formulated as follows: 

Arbitrary 

Label: Mnemonic, Operand; Descriptive Comment 

See section 1.2.2 for a description and 
example of an assembly language program. 
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Description 



Bytes Cycle 



Description 



Bytes Cycles 





ADDA, R 


Add register to A 1 






ADD A, @R 


Add data memory to A 1 






ADD A, #data 


Add immediate to A 2 


2 




ADDC A, R 


Add register with carry 1 






ADDC A, @R 


Add data memory with carry 1 






ADDC A, #data 


Add immediate with carry 2 


2- 




ANL A, R 


And register to A 1 






ANL A, @R 


And data memory to A 1 






ANL A, #data 


And immediate to A 2 


2 




ORL A, R 


Or register to A 1 




o 


ORLA, @R 


Or data memory to A 1 




"5 


ORL A, #data 


Or immediate to A 2 


2 


b 

3 


XRLA, R 


Exclusive Or register to A 1 




U 


XRL A, @R 


Exclusive or data memory to A 1 






XRLA, #data 


Exclusive or immediate to A 2 


2 




INCA 


Increment A 1 






DEC A 


Decrement A 1 






CLR A 


Clear A 1 






CPLA 


Complement A 1 






DA A 


Decimal Adjust A 1 






SWAP A 


Swap nibbles of A 1 






RLA 


Rotate A left 1 






RLC A 


Rotate A left through carry 1 






RR A 


Rotate A right 1 






RRC A 


Rotate A right through carry 1 






IN A, P 


Input port to A 1 


2 




OUTLP, A 


Output A to port 1 


2 




ANLP, #data 


And immediate to port 2 


2 


3 


ORL P, #data 


Or immediate to port 2 


2 


3 


INS A, BUS 


Input BUS to A 1 


2 


U 


OUTLBUS, A 


Output A to BUS 1 


2 


3 

a. 


ANL BUS,#data 


And immediate to BUS 2 


2 


c 


ORL BUS,#data 


Or immediate to BUS 2 


2 




MOVD A, P 


Input Expander port to A 1 


2 




MOVD P, A 


Output A to Expander port 1 


2 




ANLD P, A 


And A to Expander port 1 


2 




ORLD P, A 


Or A to Expander port 1 


2 


CD 


INCR 


Increment register 1 


1 


ts 


INC @R 


Increment data memory 1 


1 


a 
IT 


DECR 


Decrement register 1 


1 





JMP addr 


Jump unconditional 




2 


2 




JMPP @A 


Jump indirect 




1 


2 




DJNZR, addr 


Decrement register and skip 


2 


2 




JCaddr 


Jump on Carry = 1 




2 


2 




JNCaddr 


Jump on Carry = 




2 


2 




J Z addr 


Jump on A Zero 




2 


2 




JNZaddr 


Jump on A not Zero 




2 


2 


X 

u 


JTO addr 


Jump on TO = 1 




2 


2 


eg 


JNTO addr 


Jump on TO = 




2 


2 


CO 


JT1 addr 


Jump on T1 = 1 




2 


2 




JNT1 addr 


Jump on T1 = 




2 


2 




JFOaddr 


Jump on FO = 1 




2 


2 




JF1 addr 


Jump on F1 = 1 




2 


2 




JTF addr 


Jump on timer flag 




2 


2 




JNI addr 


Jump on INT= 




2 


2 




JBbaddr 


Jump on Accumulator 


Bit 


2 


2 



c 


CALL 


Jump to subroutine 2 


2 


3 

o 


RET 


Return 1 


2 


V) 


RETR 


Return and restore status 1 


2 




CLR C 


Clear Carry 1 






CPLC 


Complement Carry 1 




Ol 


CLR FO 


Clear Flag 1 




Li. 


CPL FO 


Complement Flag 1 






CLR F1 


Clear Flag 1 1 






CPL F1 


Complement Flag 1 1 






MOV A, R 


Move register to A 1 






MOV A, @R 


Move data memory to A 1 






MOV A, #data 


Move immediate to A 2 






MOV R. A 


Move A to register 1 






MOV @R, A 


Move A to data memory 1 






MOV R, #data 


Move immediate to register 2 




0) 

> 


MOV@R,#data 


Move immediate to data memory 2 




? 


MOV A, PSW 


Move PSW to A 1 




ra 


MOV PSW, A 


Move A to PSW 1 




Q 


XCH A, R 


Exchange A and register 1 






XCHA,@R 


Exchange A and data memory 1 






XCHD A, @R 


Exchange nibble of A and register 1 






MOVX A, @R 


Move external data memory to A 1 


2 




MOVX @R, A 


Move A to external data memory 1 


2 




MOVP A, @A 


Move to A from current page 1 


2 




MOVP3 A, @A 


Move to A from Page 3 1 


2 




MOV A, T 


Read Timer/Counter 1 




01 


MOV T, A 


Load Timer/Counter 1 




3 


STRTT 


Start Timer 1 




o 


STRT CNT 


Start Counter 1 




1 


STOP TCNT 


Stop Timer/Counter 1 




ENTCNT1 


Enable Timer/Counter Interrupt 1 




DISTCNTI 


Disable Timer/Counter Interrupt 1 






EN I 


Enable external interrupt 1 






DISI 


Disable external interrupt 1 







SELRBO 


Select register bank 1 




c 


SELRB1 


Select register bank 1 1 




O 


SELMBO 


Select memory bank 1 






SELMB1 


Select memory bank 1 1 






ENTO CLK 


Enable Clock output on TO 1 





NOP 



No Operation 



Mnemonics copyright Intel Corporation 1976. 



4-5 



8021 
INSTRUCTION SET SUMMARY 





Mnemonic 


Description 


Bytes 


Cycle 




ADD 


A,R 


Add register to A 








ADD 


A,@R 


Add data memory to A 








ADD 


A,#data 


Add immediate to A 


2 


2 




ADDC 


A,R 


Add with carry 








ADDC 


A,@R 


Add with carry 








ADDC 


A,#data 


Add with carry 


2 


2 




ANL 


A,R 


And register to A 








ANL 


A,@>R 


And data memory to A 








ANL 


A,#data 


And immediate to A 


2 


2 




ORL 


A,R 


Or register to A 






o 


ORL 


A,@R 


Or data memory to A 






™ 


ORL 


A,#data 


Or immediate to A 


2 


2 


F 


XRL 


A,R 


Exclusive Or register to A 






3 


XRL 


A,@R 


Exclusive or data memory to A 






U 


XRL 


A,#data 


Exclusive or immediate to A 




2 




INC 


A 


Increment A 








DEC 


A 


Decrement A 








CLR 


A 


Clear A 








CPL 


A 


Complement A 








DA 


A 


Decimal Adjust A 








SWAP 


A 


Swap nibbles of A 








RL 


A 


Rotate A left 








RLC 


A 


Rotate A left through carry 








RR 


A 


Rotate A right 








RRC 


A 


Rotate A right through carry 








IN 


A,P 


Input port to A 




2 


a 


OUTL 


P.A 


Output A to port 




2 


o 


MOVD 


A,P 


Input Expander port to A 




2 




MOVD 


P,A 


Output A to Expander port 




2 


a 


ANLD 


P,A 


And A to Expander port 




2 


— 


ORLD 


P.A 


Or A to Expander port 




2 


V 


INC 


R 


Increment register 




1 


"5> 


INC 


@R 


Increment data memory 




1 



Mnemonic 



Description 



Bytes Cycle 



JMP addr Jump unconditional 2 2 

JMPP @A Jump indirect 1 2 

DJNZ R,addr Decrement register and Jump 2 2 

on R not zero 

JC addr Jump on Carry =1 2 2 

JNC addr Jump on Carry = 2 2 

JZ addr Jump on A Zero 2 2 

JNZ addr Jump on A not Zero 2 2 

JT1 addr Jump on T1 = 1 2 2 

JNT1 addr Jump on T1 = 2 2 

JTF addr Jump on timer flag 2 2 



CALL 
RET 



Jump to subroutine 
Return 



No Operation 



Instruction Set — The following instructions, which are 
found in the 8748, have been deleted from the 8021 
instruction set. 



Data Moves 



MOV A.PSW 
MOV PSW.A 
MOVX A,@R 
MOVX @R,A 
MOVP3 A,@A 



Flags 



CLR FO 
CPL FO 
CLR F1 
CPL F1 



Branch 



JTO addr 
JNTO addr 
JFO addr 
JF1 addr 
JNI addr 
JBb addr 



EN TCNTI 
DIS TCNTI 



DIS I 
SEL RBO 
SEL RB1 
SEL MBO 
SEL MB1 
ENTO CLK 



Input/Output 



ANL P,#data 
ORL P.#data 
INS A.BUS* 
OUTL BUS.A * 
ANL BUS,#data 
ORL BUS,#data 



"These Instructions have been replaced in the 8021 by 
IN A,PO and OUTL PO,A respectively. 



CLR 


C 


Clear Carry 1 


1 


CPL 


C 


Complement Carry 1 


1 


MOV 


A,R 


Move register to A 1 


1 


MOV 


A,@R 


Move data memory to A 1 


1 


MOV 


A,#data 


Move immediate to A 2 


2 


MOV 


R,A 


Move A to register 1 


1 


MOV 


@R,A 


Move A to data memory 1 


1 


MOV 


R,#data 


Move immediate to register 2 


2 


MOV 


@R,#data 


Move immediate to data memory 2 


2 


XCH 


A,R 


Exchange A and register 1 


1 


XCH 


A,@R 


Exchange A and data memory 1 


2 


XCHD 


A,@R 


Exchange nibble of A and register 1 


1 


MOVP 


A,@A 


Move to A from current page 1 


2 


MOV 


A,T 


Read Timer/Counter 1 


1 


MOV 


T,A 


Load Timer/Counter 1 


1 


STRT 


T 


Start Timer 1 


1 


STRT 


CNT 


Start Counter 1 


1 


STOP 


TCNT 


Stop Timer/Counter 1 


1 
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MCS-48™ INSTRUCTION SET 



SYMBOLS AND ABBREVIATIONS USED 



A 


Accumulator 


AC 


Auxiliary Carry 


addr 


12-Bit Program Memory Address 


Bb 


Bit Designator (b=0-7) 


BS 


Bank Switch 


BUS 


BUS Port 


C 


Carry 


CLK 


Clock 


CNT 


Event Counter 


D 


Mnemonic for 4-Bit Digit (Nibble) 


data 


8-Bit Number or Expression 


DBF 


Memory Bank Flip-Flop 


FO, F1 


Flag 0, Flag 1 


I 


Interrupt 


P 


Mnemonic for "in-page" Operation 


PC 


Program Counter 


Pp 


Port Designator (p=1, 2 or 4-7) 


PSW 


Program Status Word 


Rr 


Register Designator (r=0, 1 or 0-7) 


SP 


Stack Pointer 


T 


Timer 


TF 


Timer Flag 


TO, T1 


Test 0, Test 1 


X 


Mnemonic for External RAM 


# 


Immediate Data Prefix 


@ 


Indirect Address Prefix 


$ 


Current Value of Program Counter 


(X) 


Contents of X 


((X)) 


Contents of Location Addressed by X 


-*- 


Is Replaced by 
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INSTRUCTION SET 



ADD A,R r Add Register Contents to Accumulator 



110 



1 r r r 



The contents of register 'r' are added to the 
accumulator. Carry is affected. 



(A )^-(A) + (Rr) 
ADDREG: ADD A.R6 



r=0-7 



Example: 
ADD A,@R r Add Data Memory Contents to Accumulator 



;ADD REG 6 CONTENTS 
;TO ACC 



110 000 r 



The contents of the resident data memory location 
addressed by register 'r' bits 0-5*are added to 
the accumulator. Carry is affected. 



Example: 



(A)^-(A) + ((Rr)) 

ADDM: MOV R0, #01 FH 
ADD A, @R0 



7 



r=0-1 

MOVE'IF' HEX TO REG 
ADD VALUE OF LOCATION 
47 TO ACC 



ADD A,#data Add Immediate Data to Accumulator 



0000 



00 11 



d7d6d5d4 d3d2d-|d 



This is a 2-cycle instruction. The specified data 
is added to the accumulator. Carry is affected 

(A)-*- (A) + data 



ADDID: ADD A,#ADDER: ;ADD VALUE OF SYMBOL 

;'ADDER' TO ACC 



Example: 
ADDC A,R r Add Carry and Register Contents to Accumulator 



111 



1 r r r 



The content of the carry bit is added to accumulator 
location and the carry bit cleared. The contents 
of register Y are then added to the accumulator. 
Carry is affected. 



(A)—(A)+(Rr)+(C) 
Example: ADDRGC: ADDC A,R4 



r=0-7 

;ADD CARRY AND REG 4 
;CONTENTS TO ACC 
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INSTRUCTION SET 



ADDC A,@R r Add Carry and Data Memory Contents to Accumulator 



0111 



00 r 



The content of the carry bit is added to accumulator 
location and the carry bit cleared. Then the contents 
of the resident data memory location addressed by 
register 'r' bits 0-5*are added to the accumulator. 
Carry is affected. 



Example: 



(A)^(A) + ((Rr)) + (C) 

ADDMC: MOV R1,#40 
ADDC A,@R1 



r=0-1 

MOVE '40' DEC TO REG 1 

ADD CARRY AND LOCATION 40 

CONTENTS TO ACC 



ADDC A,#data Add Carry and Immediate Data to Accumulator 



000 1 



11 



d7d6d5d4 d3 d2 di do 



This is a 2-cycle instruction. The content of the 
carry bit is added to accumulator location and 
the carry bit cleared. Then the specified data is 
added to the accumulator. Carry is affected. 



(A)-«- (A)+data+(C) 
ADDC A,#225 



Example: 
ANL A,R r Logical AND Accumulator With Register Mask 



;ADD CARRY AND '225' DEC 
;TO ACC 



10 1 



1 r r r 



Data in the accumulator is logically ANDed with the 
mask contained in working register 'r'. 



(A)-*- (A) AND (Rr) 
Example: ANDREG: ANL A,R3 



r=0-7 

;'AND' ACC CONTENTS WITH MASK 
;IN REG 3 



ANL A,@R r Logical AND Accumulator With Memory Mask 



10 1 



r 



Data in the accumulator is logically ANDed with the 
mask contained in the data memory location referenced 
by register 'r', bits 0-5? 

(A)-«- (A) AND ((Rr)) r=0-1 



Example: 



ANDDM: MOV R0,#03FH 
ANL A, @R0 



MOVE '3F' HEX TO REG 
'AND' ACC CONTENTS WITH 
MASK IN LOCATION 63 
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INSTRUCTION SET 



ANL A,#data Logical AND Accumulator With Immediate Mask 



10 1 



00 11 



d7d6d 5 d4 d3d2d-ido 



This is a 2-cycle instruction. Data in the accumulator 
is logically ANDed with an immediately-specified mask. 



(A)-«- (A) AND data 
Examples: ANDID: ANL A,#0AFH 

ANL A,#3+X/Y 



'AND' ACC CONTENTS 
WITH MASK 10101111 
'AND' ACC CONTENTS 
WITH VALUE OF EXP 
'3+X/Y' 

ANL BUS,#data Logical AND BUS With Immediate Mask (Not in 8021) 



10 1 



10 00 



d7d6d 5 d4 d 3 d2d-|d 



This is a 2-cycle instruction. Data on the BUS port is 
logically ANDed with an immediately-specified mask. This 
instruction assumes prior specification of an 'OUTL 
BUS, A' instruction. 



(BUS)-*- (BUS) AND data 
Example: ANDBUS: ANL BUS, #MASK 



'AND' BUS CONTENTS 
WITH MASK EQUAL VALUE 
OF SYMBOL 'MASK' 



ANL Pp,#data Logical AND Port 1-2 With Immediate Mask (Not in 8021) 



100 1 



10pp d7d 6 d 5 d4 d 3 d 2 d 1 d 



This is a 2-cycle instruction. Data on port 'p' is 
logically ANDed with an immediately-specified mask. 



Example: 



(Pp)-«- (Pp) AND data 
ANDP2: ANL P2,#0F0H 



p=1-2 

'AND' PORT 2 CONTENTS 
WITH MASK 'F0' HEX 
(CLEAR P20-23) 



ANLD Pp,A Logical AND Port 4-7 With Accumulator Mask 



10 1 



1 1 pp 



This is a 2-cycle instruction. Data on port 'p' is 
logically ANDed with the digit mask contained in 
accumulator bits 0-3. 

(Pp)-«- (Pp) AND (AO-3) p=4-7 
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INSTRUCTION SET 



Note: The mapping of port 'p' to opcode bits 0-1 



is as follows: 








1 


Port 







4 




1 


5 




1 


6 




1 1 


7 



Example: ANDP4: ANLD P4,A 



CALL address Subroutine Call 



;'AND' PORT 4 CONTENTS 
;WITH ACC BITS 0-3 



Example: 



a 10 a 9 a 8 1 



100 



a 7 a 6 a 5 a 4 a 3 a 2 a-| a 



This is a 2-cycle instruction. The program counter and 
PSW bits 4-7 are saved in the stack. The stack pointer 
(PSW bits 0-2) is updated. Program control is then 
passed to the location specified by 'address'. PC 
bit 11 is determined by the most recent SEL MB instruction. 

Execution continues at the instruction following the 
CALL upon return from the subroutine. 

((SP)) - (PC), (PSW 4 _ 7 ) 
(SP) — (SP)+1 
(PC 8 _i ) - (addr 8 . 10 ) 

(PCrj-7) - addro-y 
(PC 11 )-DBF 

Add three groups of two numbers. Put subtotals in 
locations 50, 51 and total in location 52. 



MOV R0,#50 

BEGADD: MOV A,R1 

ADD A.R2 
CALL SUBTOT 
ADD A R3 
ADD A,R4 
CALL SUBTOT 
ADD A,R5 
ADD A,R6 
CALL SUBTOT 

SUBTOT: MOV @R0,A 



INC R0 
RET 



MOVE '50' DEC TO ADDRESS 

REG 

MOVE CONTENTS OF REG 1 

TO ACC 

ADD REG 2 TO ACC 

CALL SUBROUTINE 'SUBTOT 

ADD REG 3 TO ACC 

ADD REG 4 TO ACC 

CALL SUBROUTINE 'SUBTOT' 

ADD REG 5 TO ACC 

ADD REG 6 TO ACC 

CALL SUBROUTINE 'SUBTOT 

MOVE CONTENTS OF ACC TO 
LOCATION ADDRESSED BY 
REG 

INCREMENT REG 
RETURN TO MAIN PROGRAM 
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INSTRUCTION SET 



CLR A Clear Accumulator 



00 10 



111 



The contents of the accumulator are cleared to zero. 
A-*-0 
CLR C Clear Carry Bit 



100 1 



111 



During normal program execution, the carry bit can 

be set to one by the ADD, ADDC, RLC, CPL C, RRC, and 

DAA instructions. This instruction resets the carry bit to zero. 

C-*-0 

CLR F1 Clear Flag 1 (Not in 8021) 



10 10 



10 1 



Flag 1 is cleared to zero. 
(F1)-«-0 
CLR F0 Clear Flag (Not in 8021) 



1000 



10 1 



Flag is cleared to zero. 
(F0)^0 
CPL A Complement Accumulator 



00 11 



111 



The contents of the accumulator are complemented. 
This is strictly a one's complement. Each one is 
changed to zero and vice-versa. 

(A)-*- NOT (A) 

Example: Assume accumulator contains 01101010. 

CPLA: CPL A ;ACC CONTENTS ARE COMPLE- 

MENTED TO 10010101 

CPL C Complement Carry Bit 



10 10 



111 



The setting of the carry bit is complemented; one is 
changed to zero, and zero is changed to one. 

(C)^-NOT(C) 

Example: Set C to one; current setting is unknown. 

CT01: CLRC ;C IS CLEARED TO ZERO 

CPL C ;C IS SET TO ONE 
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INSTRUCTION SET 



CPL FO Complement Flag (Not in 8021) 



100 1 



10 1 



The setting of flag is complemented; one is 
changed to zero, and zero is changed to one. 



F0-«- NOT (F0) 
CPL F1 Complement Flag 1 



(Not in 8021) 



10 11 



10 1 



The setting of flag 1 is complemented; one is 
changed to zero, and zero is changed to one. 

(F1H-NOT (F1) 

DA A Decimal Adjust Accumulator 



10 1 



111 



The 8-bit accumulator value is adjusted to form two 
4-bit Binary Coded Decimal (BCD) digits following 
the binary addition of BCD numbers. The carry bit 
C is affected. If the contents of bits 0-3 are 
greater than nine, or if AC is one, the accumulator 
is incremented by six. 

The four high-order bits are then checked. If bits 
4-7 exceed nine, or if C is one, these bits are 
increased by six. If an overflow occurs, C is 
set to one. 

Example: Assume accumulator contains 10011011. 



DA A 



c 


AC 


7 






4 


3 















1 








1 


1 




1 


1 
1 


1 










1 





1 


1 
1 















1 


1 


























1 



;ACC ADJUSTED TO 00000001 
;WITH C SET 



ADD SIX TO BITS 0-7 

ADD SIX TO BITS 4-7 
OVERFLOW TO C 



DEC A Decrement Accumulator 



0000 



111 



The contents of the accumulator are decremented by one. 
(A)-*- (A)-1 
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INSTRUCTION SET 



Example: Decrement contents of external data memory location 63. 



MOV R0,#3FH 
MOVX A,@R0 

DEC A 
MOVX @R0,A 



MOVE '3F' HEX TO REG 

MOVE CONTENTS OF LOCATION 63 

TO ACC 

DECREMENT ACC 

MOVE CONTENTS OF ACC TO 

LOCATION 63 IN EXPANDED 

MEMORY 



DEC R r Decrement Register (Not in 8021) 



1100 



1 r r r 



The contents of working register 'r' are decremented 
by one. 

(RrH- (Rr)-1 r=0-7 

Example: DECR1: DEC R1 DECREMENT CONTENTS OF REG 1 

DIS I Disable External Interrupt (Not in 8021) 



000 1 



10 1 



External interrupts are disabled. A low signal on 
the interrupt input pin has no effect. 

DIS TCNTI Disable Timer/Counter Interrupt (Not in 8021) 



00 11 



10 1 



Timer/counter interrupts are disabled. Any pending 
timer interrupt request is cleared. The interrupt 
sequence is not initiated by an overflow, but the 
timer flag is set and time accumulation continues. 

DJNZ R r , address Decrement Register and Test 



1110 



1 r r r 



a 7 a 6 a 5 a 4 a 3 a 2 a-| a 



This is a 2-cycle instruction. Register 'r' is 
decremented and tested for zero. If the register 
contains all zeros, program control falls through 
to the next instruction. If the register contents 
are not zero, control jumps to the specified 'address'. 

The address in this case must evaluate to 8-bits, that 
is, the jump must be to a location within the current 
256-location page. 



(Rr)-*- (Rr)-1 
If Rr not 
(PCrj-7)-*- addr 



r=0-7 
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Note: A 12-bit address specification does not cause an 
error if the DJNZ instruction and the jump target are 
on the same page. If the DJNZ instruction begins in 
location 255 of a page, it must jump to a target 
address on the following page. 



Example: Increment values in data memory locations 50-54. 

;MOVE '50' DEC TO ADDRESS 
;REG 

;MOVE '5' DEC TO COUNTER 
;REG 3 

INCREMENT CONTENTS OF 
.LOCATION ADDRESSED BY 
;REG 

INCREMENT ADDRESS IN REG 
INCRT ;DECREMENT REG 3 — JUMP TO 
;'INCRT IF REG 3 NONZERO 
;'NEXT ROUTINE EXECUTED 
;IF R3 IS ZERO 



MOV R0,#50 
MOV R3,#5 
INCRT: INC @R0 



INC R0 
DJNZ R3, 

NEXT — 



EN I Enable External Interrupt (Not in 8021 



00 



10 1 



External interrupts are enabled. A low signal on 
the interrupt input pin initiates the interrupt 
sequence. 

EN TCNTI Enable Timer/Counter Interrupt (Not in 8021) 



00 10 



10 1 



Timer/counter interrupts are enabled. An overflow 
of the timer/counter initiates the interrupt sequence. 

ENT0 CLK Enable Clock Output (Not in 8021) 



111 



10 1 



The test pin is enabled to act as the clock output. 
This function is disabled by a system reset. 

Example: EMTST0: ENT0 CLK ;ENABLE TO AS CLOCK OUTPUT 

IN A,Pp Input Port or Data to Accumulator 



00 00 



1 Op p 



This is a 2-cycle instruction. Data present on port 'p' 
is transferred (read) to the accumulator. In the 8021 
IN A,P2 inputs P20-P23 to A0-A3 while A4-A7 is set 
to zero. 



(A)-- (Pp) 



p=1-2 
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Example: INP12: IN A,P1 

MOV R6,A 

IN A.P2 

MOV R7,A 
INC A Increment Accumulator 



INPUT PORT 1 CONTENTS 

TO ACC 

MOVE ACC CONTENTS TO 

REG 6 

INPUT PORT 2 CONTENTS 

TO ACC 

MOVE ACC CONTENTS TO REG 7 



000 1 



111 



The contents of the accumulator are incremented 
by one. 

(A)-*- (A)+1 

Example: Increment contents of location 100 in external 
data memory. 
INCA: MOV R0,#100 



MOVX A,@R0 

INCA 
MOVX @R0,A 

INC R r Increment Register 



MOVE '100' DEC TO ADDRESS 

REG 

MOVE CONTENTS OF LOCATION 

100 TO ACC 

INCREMENT A 

MOVE ACC CONTENTS TO 

LOCATION 100 



000 1 



1 r r r 



The contents of working register V are incremented 
by one. 



Example: 



(Rr)-*- (Rr)+1 
INCR0: INC R0 



r=0-7 

INCREMENT ADDRESS REG 



INC @R r Increment Data Memory Location 



000 1 



OOOr 



The contents of the resident data memory location 
addressed by register 'r' bits0-5*are incremented 
by one. 



((Rr))-*- ((Rr))+1 



r=0-1 



Example: 



INCDM: MOV R1,#03FH ;MOVE ONES TO REG 1 

INC @R1 INCREMENT LOCATION 63 
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IN A,P0 



Input of Port Data to Accumulator 



Same as INS A, BUS except no RD pulse generated. 

INS A,BUS Strobed Input of BUS Data to Accumulator 



0000 



100 



This is a 2-cycle instruction. Data present on the 
BUS port isjransferred (read) to the accumulator 
when the RD pulse is dropped. (Refer to section on 
programming memory expansion for details). 



(A)-t- (BUS) 
INPBUS: INS A.BUS 



;INPUT BUS CONTENTS 
;TO ACC 



Example: 
JBb address Jump If Accumulator Bit is Set (Not in 8021) 



b 2 b-| b 1 10 



a 7 a 6 a 5 a 4 a 3 a 2 a-| a 



This is a 2-cycle instruction. Control passes to the 
specified address if accumulator bit 'b' is set 
to one. 



(PC0-7)-*- addr 
(PC) = (PC)+2 

Example: JB4IS1: JB4 NEXT 
JC address Jump If Carry Is Set 



If Bb=1 
If Bb=0 

;JUMP TO 'NEXT ROUTINE 
;IF ACC BIT 4=1 



1111 



0110 



a 7 a 6 a 5 a 4 a 3 a 2 a-| a 



This is a 2-cycle instruction. Control passes to the 
specified address if the carry bit is set to one. 



(PCo-7)-*- addr 
(PC) = (PC)+2 



If C=1 
If C=0 



Example: JC1: JC OVFLOW 
JF0 address Jump If Flag Is Set (Not in 8021 



;JUMP TO 'OVFLOW ROUTINE 
;IFC=1 



1011 



0110 



a 7 a 6 a 5 a 4 a 3 a 2 a 1 a 



This is a 2-cycle instruction. Control passes to the 
specified address if flag is set to one. 



(PC0-7)-*- addr 
(PC) = (PC)+2 

Example: JF0IS1: JF0 TOTAL 



If F0=1 
If F0=0 

;JUMP TO TOTAL' ROUTINE 
;IF F0=1 
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JF1 address Jump If Flag 1 Is Set (Not in 8021) 



111 



110 



a 7 a 6 a 5 a 4 a 3 a 2 a-| a 



This is a 2-cycle instruction. Control passes to the 
specified address if flag 1 is set to one. 



(PC0-7)-*- addr 
(PC) = (PC)+2 

Example: JF1IS1: JF1 FILBUF 



If F1 = 1 
IF F1=0 

;JUMPTO 'FILBUF' 
;ROUTINE IF F1 = 1 



JMP address Direct Jump Within 2K Block 



l 10 a 9 a 8 ° 



100 



a 7 a 6 a 5 a 4 a 3 a 2 a-| a 



This is a 2-cycle instruction. Bits 0-10 of the program 
counter are replaced with the directly-specified 
address. The setting of PC bit 11 is determined by 
the most recent SELECT MB instruction. 

(PC 8 _ 10 )-«-addr 8-10 
(PC -7)-«-addr 0-7 
(PCn^DBF 



Example: JMP SUBTOT 
JMP $-6 

JMP 2FH 



JUMP TO SUBROUTINE 'SUBTOT 
JUMP TO INSTRUCTION SIX LOCATIONS 
BEFORE CURRENT LOCATION 
JUMP TO ADDRESS '2F' HEX 



JMPP @A Indirect Jump Within Page 



1011 11 



Example: 



This is a 2-cycle instruction. The contents of the 
program memory location pointed to by the accumulator 
are substituted for the 'page' portion of the program 
counter (PC bits 0-7). 

(PC0-7)*- ((A)) 

Assume accumulator contains 0FH. 

JMPPAG: JMPP @A ;JUMP TO ADDRESS STORED IN 

LOCATION 15 IN CURRENT PAGE 



JNC address Jump If Carry Is Not Set 



1110 



110 



a 7 a 6 a 5 a 4 a 3 a 2 a-, a 



This is a 2-cycle instruction. Control passes to the 
specified address if the carry bit is not set, that 
is, equals zero. 
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(PC -7)-«- addr 
(PC) = (PC)+2 


If c=o 

IF C=1 


Example: JCO: JNC NOVFLO 


;JUMP TO 'NOVFLO' ROUTINE 
;lf C=0 


J Nl address Jump If Interrupt Input is Low (Not in 8021) 



100 110 



a 7 a 6 a 5 a 4 a 3 a 2 a-, a 



This is a 2-cycle instruction. Control passes to the 
specified address if the interrupt input signal is 
low (=0), that is, an external interrupt has 
been signaled. (This signal initiates an interrupt 
service sequence if the external interrupt is enabled.) 





(PC -7)-«- addr 
(PC) = (PC)+2 


If l=0 
If 1=1 


Example: LOC 3: JNI EXTINT ;JUMP TO 'EXTINT ROUTINE 

;lf l=0 


JNT0 address Jump If Test Is Low (Not in 8021) 










10 


110 


a 7 a 6 a 5 a 4 a 3 a 2 a-, a 




This is a 2-cycle i 
specified address 


nstruction. Control passes to the 
if the test signal is low 




(PC0-7H 
(PC) = (F 


t- addr 
3 C)+2 


If T0=0 
If T0=1 



Example: JT0LOW: JNT0 60 
JNT1 address Jump If Test 1 Is Low 



;JUMP TO LOCATION 60 DEC 
;IFT0=0 



10 



110 



a 7 a 6 a 5 a 4 a 3 a 2 a-, a 



This is a 2-cycle instruction. Control passes to the 
specified address, if the test 1 signal is low. 



(PCo-7)-*- addr 
(PC) = (PC)+2 



If T1=0 

If T1=1 



JNZ address Jump If Accumulator Is Not Zero 



100 1 



110 



a 7 a 6 a 5 a 4 a 3 a 2 a-| a 



This is a 2-cycle instruction. Control pases to the 
specified address if the accumulator contents are 
nonzero at the time this instruction is executed. 



(PC -7)-«- addr 
(PC) = (PC)+2 

Example: JACCN0: JNZ 0ABH 

Mnemonics copyright Intel Corporation 1976. 



If A^0 
If A=0 

;JUMP TO LOCATION 'AB' HEX 
;IF ACC VALUE IS NONZERO 



4-19 



INSTRUCTION SET 



JTF address Jump If Timer Flag Is Set 



000 1 



110 



a 7 a 6 a 5 a 4 a 3 a 2 a-| a 



This is a 2-cycle instruction. Control passes to the 
specified address if the timer flag is set to one, 
that is, the timer/counter register has overflowed. 
Testing the timer flag resets it to zero. (This 
overflow initiates an interrupt service sequence 
if the timer-overflow interrupt is enabled.) 



(PC . 7 )-*-addr 
(PC) = (PC)+2 



If TF=1 
If TF=0 



Example: JTF1: JTF TIMER 
JT0 address Jump If Test Is High (Not in 8021 



; JUMP TO TIMER' ROUTINE 
;IFTF=1 













00 11 110 


a 7 a 6 a 5 a 4 a 3 


a 2 a-| a 




This is a 2-cycle i 
specified address 


nstruction. Control 
if the test signal 


passes to the 
s high (=1). 




(PC - 7 )-*-addr 
(PC) = (PC)+2 


If T0=1 

If T0=0 




Example: 


JT0HI: JT0 53 


;JUMP TO LOCATION 53 DEC 
;IFT0=1 


JT1 address Jump If Test 


1 Is High 














10 1 110 


a 7 a 6 a 5 a 4 a 3 


a 2 a-| a 




This is a 2-cycle i 
specified address 


nstruction. Control 
if the test 1 signal 


passes to the 
is high (=1). 




(PC - 7 )-«-addr 
(PC) = (PC)+2 


If T1 = 1 
If T1=0 





Example: JT1HI: JT1 COUNT 
JZ address Jump If Accumulator Is Zero 



;JUMP TO 'COUNT ROUTINE 



1100 



110 



a 7 a 6 a 5 a 4 a 3 a 2 a-, a 



This is a 2-cycle instruction. Control passes to the 
specified address if the accumulator contains all 
zeros at the time this instruction is executed. 



(PC - 7 )-*- addr 
(PC) = (PC)+2 

Example: JACCO: JZ 0A3H 



If A=0 
If A*0 

;JUMP TO LOCATION 'A3' HEX 
;IF ACC VALUE IS ZERO 
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4-20 



INSTRUCTION SET 



MOV A,#data Move Immediate Data to Accumulator 



00 10 



00 11 



d7d 6 d5cl4 d 3 d2d-|do 



This is a 2-cycle instruction. The 8-bit value 
specified by 'data' is loaded in the accumulator. 



Example: 



(A)-*- data 
MOV A,#0A3H 



;MOVE 'A3' HEX TO ACC 



MOV A,PSW Move PSW Contents to Accumulator (Not in 8021) 



1100 



111 



The contents of the program status word are moved 
to the accumulator. 

(A)-«- (PSW) 

Example: Jump to 'RB1SET' routine if PSW bank switch, bit 4, 
is set. 



BSCHK: MOV A.PSW 
JB4 RB1SET 



MOVE PSW CONTENTS TO ACC 
JUMP TO 'RB1SET' IF ACC 
BIT 4=1 



MOV A,R r Move Register Contents to Accumulator 



1111 



1 r r r 



8-bits of data are moved from working register 'r' 
into the accumulator. 



(A)— (Rr) 
Example: MAR: MOV A,R3 



r=0-7 

;MOVE CONTENTS OF REG 3 
;TO ACC 



MOV A,@R r Move Data Memory Contents to Accumulator 



1111 00r 



The contents of the resident data memory location 
addressed by bits 0-5*of register 'r' are moved to 
the accumulator. Register Y contents are unaffected. 



(A)*- ((Rr)) 



r=0-1 



Example: Assume R1 contains 00110110. 

MADM: MOV A,@R1 ;MOVE CONTENTS OF DATA MEM 

;LOCATION 54 TO ACC 
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*0-6 for 8039/8049 



INSTRUCTION SET 



MOV A,T Move Timer/Counter Contents to Accumulator 



100 



00 10 



The contents of the timer/event-counter register 
are moved to the accumulator. 

(A)— (T) 

Example: Jump to "EXIT" routine when timer reaches '64', 

that is, when bit 6 set — assuming initialization 64, 

;MOVE TIMER CONTENTS TO 
;ACC 



TIMCHK: MOV A,T 
JB6EXIT 



JUMP TO 'EXIT IF ACC BIT 
6=1 



MOV PSW,A Move Accumulator Contents to PSW (Not in 8021) 



110 1 



111 



Example: 



The contents of the accumulator are moved into the 
program status word. All condition bits and the 
stack pointer are affected by this move. 

(PSW)-<- (A) 

Move up stack pointer by two memory locations, 
that is, increment the pointer by one. 



INCPTR: MOV A.PSW 
INC A 
MOV PSW.A 



MOVE PSW CONTENTS TO ACC 
INCREMENT ACC BY ONE 
MOVE ACC CONTENTS TO PSW 



MOV R r ,A Move Accumulator Contents to Register 



10 10 



1 r r r 



The contents of the accumulator are moved to 
register 'r'. 



(Rr)^- (A) 
Example: MRA: MOV R0,A 



r=0-7 

;MOVE CONTENTS OF ACC TO 
;REG 



MOV R r ,#data Move Immediate Data to Register 



10 11 



1 r 2 r 1 r d7d 6 d 5 d 4 d 3 d2d-|d 



This is a 2-cycle instruction. The 8-bit value 
specified by 'data' is moved to register 'r'. 



(Rr)-«- data 



r=0-7 
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4-22 



INSTRUCTION SET 



Examples: MIR4: MOV R4,#HEXTEN 



MIR 5: MOV R5,#PI*(R*R) 



MIR 6: MOV R6, #0ADH 



THE VALUE OF THE SYMBOL 
'HEXTEN' IS MOVED INTO 
REG 4 

THE VALUE OF THE 
EXPRESSION 'PI*(R*R) 
IS MOVED INTO REG 5 
'AD' HEX IS MOVED INTO 
REG 6 



MOV @R r ,A Move Accumulator Contents to Data Memory 



10 10 



000 r 



This is a 2-cycle instruction. The contents of the 
accumulator are moved to the resident data 
memory location whose address is specified by bits 
0-5* of register 'r\ Register 'r' contents are 
unaffected. 

((Rr))^- (A) r=0-1 

Example: Assume R0 contains 00000111. 

MDMA: MOV @R0,A ;MOVE CONTENTS OF ACC TO 

LOCATION 7 (REG 7) 

MOV @R r ,#data Move Immediate Data to Data Memory 



10 11 



00 r 



d7d 6 d 5 d4 d3d2d-|d 



This is a 2-cycle instruction. The 8-bit value 
specified by 'data' is moved to the resident data 
memory location addressed by register 'r', bits 0-5? 



((Rr)H- data 



r=0-1 



Examples: Move the hexadecimal value AC3F to locations 62-63. 



MIDM: MOV R0,#62 

MOV @R0,#0ACH 
INC R0 
MOV@R0,#3FH 



MOVE '62' DEC TO ADDR REG 
MOVE 'AC HEX TO LOCATION 62 
INCREMENT REG TO '63' 
MOVE '3F' HEX TO LOCATION 63 



MOV T,A Move Accumulator Contents to Timer/Counter 



110 



00 10 



Example: 



The contents of the accumulator are moved to the 
timer/event-counter register. 

CO*- (A) 

Initialize and start event counter. 



INITEC: CLR A 

MOV T,A 
STRT CNT 



CLEAR ACC TO ZEROS 

MOVE ZEROS TO EVENT COUNTER 

START COUNTER 
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4-23 



INSTRUCTION SET 



MOVD A,Pp Move Port 4-7 Data to Accumulator 



0000 



11 pp 



This is a 2-cycle instruction. Data on 8243 port 
'p' is moved (read) to accumulator bits 0-3. 
Accumulator bits 4-7 are zeroed. 



(0-3)- 
(4-7)- 



(Pp) 




p=4-7 



Note: Bits 0-1 of the opcode are used to represent ports 
4-7. If you are coding in binary rather than assembly 
language, the mapping is as follows: 
Bits 1 Port 






4 


1 


5 


1 


6 


1 1 


7 



Example: INPPT5: MOVD A,P5 
MOVD Pp,A Move Accumulator Data to Port 4-7 



;MOVE PORT 5 DATA TO ACC 
;BITS 0-3, ZERO ACC BITS 4-7 



00 11 



1 1 PP 



This is a 2-cycle instruction. Data in accumulator 
bits 0-3 is moved (written) to 8243 port 'p'. 
Accumulator bits 4-7 are unaffected. (See NOTE 
above regarding port mapping.) 



(Pp)^(A _ 3 ) 



p=4-7 



Example: Move data in accumulator to ports 4 and 5. 



OUTP45: MOVD P4,A 
SWAP A 
MOVD P5.A 



MOVE ACC BITS 0-3 TO PORT 4 
EXCHANGE ACC BITS 0-3 AND 4-7 
MOVE ACC BITS 0-3 TO PORT 5 



MOVP A,@A Move Current Page Data to Accumulator 



10 10 00 11 



The contents of the program memory location addressed 
by the accumulator are moved to the accumulator. Only 
bits 0-7 of the program counter are* affected, limiting 
the program memory reference to the current page. The 
program counter is restored following this operation 

(PC - 7 )^ (A) 
(A)-.- ((PC)) 

Note: This is a 1-byte, 2-cycle instruction. If it appears 
in location 255 of a program memory page, @A addresses 
a location in the following page. 
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INSTRUCTION SET 



Example: MOV1 28: MOV A,#1 28 
MOVP A,@A 



MOVE '128' DEC TO ACC 
CONTENTS OF 129th LOCATION 
IN CURRENT PAGE ARE MOVED TO 
ACC 



MOVP3 A,@A Move Page 3 Data to Accumulator (Not in 8021) 



1110 00 11 



Example: 



TABSCH: 



This is a 2-cycle instruction. The contents of the 
program memory location (within page 3) addressed by 
the accumulator are moved to the accumulator. The 
program counter is restored following this operation. 

(PC . 7 K(A) 

(PCfrnKOOH 

(AM(PC)) 

Look up ASCII equivalent of hexadecimal code in table 
contained at the beginning of page 3. Note that ASCII 
characters are designated by a 7-bit code; the eighth 
bit is always reset. 

;MOVE 'B8' HEX TO ACC (10111000) 
;LOGICAL AND ACC TO MASK BIT 
;7 (00111000) 

;MOVE CONTENTS OF LOCATION 
;'38' HEX IN PAGE 3 TO ACC 
; (ASCI I '8') 
Access contents of location in page 3 labelled TAB1. 
Assume current program location is not in page 3. 
TABSCH: MOV A,#LOW TAB1 ;ISOLATE BITS 0-7 OF LABEL 

;ADDRESS VALUE 
MOVP3A,@A ;MOVE CONTENTS OF PAGE 3 

[LOCATION LABELED TAB1' 
;TO ACC 

MOVX A,@R r Move External-Data-Memory Contents to Accumulator 



MOV A,#0B8H 
ANL A,#7FH 

MOVP3 A,@A 



10 r 



(Not in 8021) 



This is a 2-cycle instruction. The contents of the 
external data memory location addressed by register 
Y are moved to the accumulator. Register 'r' contents 
are unaffected. 

(A)^- ((Rr)) r=0-1 

Example: Assume R1 contains 01110110. 

MAXDM: MOVX A,@R1 ;MOVE CONTENTS OF LOCATION 

;118TO ACC 
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INSTRUCTION SET 



MOVX @R r ,A Move Accumulator Contents to External Data Memory 



100 1 



000 r 



(Not in 8021) 



This is a 2-cycle instruction. The contents of the 
accumulator are moved to the external data memory 
location addressed by register 'r'. Register Y 
contents are unaffected. 



((Rr))— A 

Example: Assume R0 contains 11000111. 
MXDMA: MOVX @R0,A 



MOVE CONTENTS OF ACC TO 
LOCATION 199 IN EXPANDED 
DATA MEMORY 



NOP The NOP Instruction 



0000 



0000 



No operation is performed. Execution continues with 
the following instruction. 

ORL A,R r Logical OR Accumulator With Register Mask 



100 



1 r r r 



Data in the accumulator is logically ORed with the 
mask contained in working register Y. 



(A)-<- (A) OR (Rr) 
ORREG: ORL A,R4 



r=0-7 



Example 
ORL A,@R r Logical OR Accumulator With Memory Mask 



;'OR' ACC CONTENTS WITH 
;MASK IN REG 4 



10 



OOOr 



Data in the accumulator is logically ORed with the mask 
contained in the resident data memory location referenced by 
register 'r', bits 0-5* 



Example: 



( A)^- (A) OR ((Rr)) 

ORDM: MOV R0,#3FH 
ORL A,@R0 



r=0-1 

MOVE '3F' HEX TO REG 

'OR' ACC CONTENTS WITH MASK 

IN LOCATION 63 



ORL A,#data Logical OR Accumulator With Immediate Mask 



100 



00 11 



d7 d 6 d 5d4 d3d2d-]do 



This is a 2-cycle instruction. Data in the accumulator 
is logically ORed with an immediately-specified mask. 



(A)-«- (A) OR data 
Example: ORID: ORL A,#'X' 
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;'OR' ACC CONTENTS WITH MASK 
,01011000 (ASCII VALUE OF 'X') 

*0-6 for 8039/8049 



INSTRUCTION SET 



ORL BUS,#data Logical OR BUS With Immediate Mask (Not in 8021) 



1000 



1000 



d7d 6 d 5 d4 d3d2 d-|do 



This is a 2-cycle instruction. Data on the BUS port is 
logically ORed with an immediately-specified mask. This 
instruction assumes prior specification of an 'OUTL BUS, A' 
instruction. 

(BUS)-*- (BUS) OR data 

Example: ORBUS: ORL BUS,#HEXMSK ;'OR' BUS CONTENTS WITH 

;MASK EQUAL VALUE OF SYMBOL 
;'HEXMSK' 

ORL Pp, #data Logical OR Port 1 or 2 With Immediate Mask (Not in 

8021) 



1000 10pp d7d 6 d 5 d4 d3d2d-|d 



This is a 2-cycle instruction. Data on port 'p' 

is logically ORed with an immediately-specified mask. 

(Pp)^«- (Pp) OR data p=1-2 

Example: ORP1: ORL P1, #0FFH ;'OR' PORT 1 CONTENTS WITH 

;MASK 'FF' HEX ( SET PORT 1 
;TO ALL ONES) 

ORLD Pp,A Logical OR Port 4-7 With Accumulator Mask 



1000 



1 1 pp 



This is a 2-cycle instruction. Data on port 'p' is 
logically ORed with the digit mask contained in 
accumulator bits 0-3. 
(Pp)-H- (Pp) OR (A _ 3 ) p=4-7 

Example: ORP7: ORLD P7,A ;'OR' PORT 7 CONTENTS 

;WITH ACC BITS 0-3 

OUTL P0,A Output Accumulator Data to Port (8021 only) 



1001 0000 



OUTL BUS,A Output Accumulator Data to BUS (Not in 8021) 



0000 00 10 



This is a 2-cycle instruction. Data residing in the 
accumulator is transferred (written) to the BUS port and 
latched. The latched data remains valid until altered by 
another OUTL instruction. Any other instruction 
requiring use of the BUS port (except INS) destroys the 
contents of the BUS latch. This includes expanded 
memory operations (such as the MOVX instruction). 
Logical operations on BUS data (AND, OR) assume the 
OUTL BUS,A instruction has been issued previously. 



Does not 
apply for 
h OUTL 
P0,A 
of 8021 



(BUS)-*- (A) 
Example: OUTLBP: OUTL BUS.A 
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;OUTPUT ACC CONTENTS TO BUS 



INSTRUCTION SET 



OUTL Pp,A Output Accumulator Data to Port 1 or 2 



00 11 



1 Opp 



This is a 2-cycle instruction. Data residing in the 
accumulator is transferred (written) to port 'p' and 
latched. 



Example: 



(PP)^-(A) 

OUTLP: MOV A,R7 
OUTL P2,A 
MOVA.R6 
OUTL P1.A 



p=1-2 

MOVE REG 7 CONTENTS TO ACC 
OUTPUT ACC CONTENTS TO PORT 2 
MOVE REG 6 CONTENTS TO ACC 
OUTPUT ACC CONTENTS TO PORT 1 



RET Return Without PSW Restore 



1000 



00 11 



This is a 2-cycle instruction. The stack pointer 
(PSW bits 0-2) is decremented. The program counter 
is then restored from the stack. PSW bits 4-7 are 
not restored. 



(SP)- 
(PC) 



(SP)-1 
((SP)) 



RETR Return With PSW Restore (Not in 8021) 



100 1 00 11 



This is a 2-cycle instruction. The stack pointer is 
decremented. The program counter and bits 4-7 of the 
PSW are then restored from the stack. Note that RETR 
should be used to return from an interrupt, but 
should not be used within the interrupt service 
routine as it signals the end of an interrupt routine. 

(SP)-«- (SP)-1 
(PC)-*- ((SP)) 
(PSW 4-7)-*- ((SP)) 



RL A Rotate Left Without Carry 



1110 111 



The contents of the accumulator are rotated left one 
bit. Bit 7 is rotated into the bit position. 



(AN+1)-*- (Ah) 
(A0)^ (A7) 



n=0-6 



Example: Assume accumulator contains 10110001. 

RLNC: RL A ;NEW ACC CONTENTS ARE 01100011. 
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INSTRUCTION SET 



RLC A Rotate Left Through Carry 



1111 



0111 



The contents of the accumulator are rotated left one 
bit. Bit 7 replaces the carry bit; the carry bit is 
rotated into the bit position. 



(AN+1)-*- (An) 



n=0-6 



(A0) 
(O- 



-(C) 
(A7) 



Example: Assume accumulator contains a 'signed' number; 
isolate sign without changing value. 



RLTC: CLR C 
RLC A 

RR A 



RR A Rotate Right Without Carry 



CLEAR CARRY TO ZERO 
ROTATE ACC LEFT, SIGN 
BIT (7) IS PLACED IN CARRY 
ROTATE ACC RIGHT — VALUE 
(BITS 0-6) IS RESTORED, 
;CARRY UNCHANGED, BIT 7 
;IS ZERO 



111 



111 



The contents of the accumulator are rotated right 
one bit. Bit is rotated into the bit 7 position 



(An) 
(A7)- 



(AN+1) 
(A0) 



n=0-6 



Assume accumulator contains 10110001. 

RRNC: RR A ;NEW ACC CONTENTS ARE 11011000 



Example 
RRC A Rotate Right Through Carry 



110 



111 



The contents of the accumulator are rotated right one 
bit. Bit replaces the carry bit; the carry bit is 
rotated into the bit 7 position. 

n=0-6 



(AnK 


- (An+1 


(A7K 


-(C) 


(C)^- 


)A0) 



Example: 



Assume carry is not set and accumulator contains 
10110001. 

RRTC:RRCA ;CARRY IS SET AND ACC 

;CONTAINS 01011000 
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INSTRUCTION SET 



SEL MBO Select Memory Bank (Not in 8021) 



1110 



10 1 



PC bit 11 is set to zero on next JMP or CALL instruction. 
All references to program memory addresses fall within 
the range 0-2047. 

(DBF)-«-0 

Example: Assume program counter contains 834 Hex. 



SEL MBO 
JMP $+20 



;SELECT MEMORY BANK 
;JUMP TO LOCATION 
;48 HEX 



SEL MB1 Select Memory Bank 1 (Not in 8021) 



1111 



10 1 



PC bit 11 is set to one on next JMP or CALL instruction. 
All references to program memory addresses fall 
within the range 2048-4095. 



(DBF)-«- 1 

SEL RB0 Select Register Bank 



(Not in 8021 



1100 10 1 



PSW bit 4 is set to zero. References to working 
registers 0-7 address data memory locations 0-7. 
This is the recommended setting for normal program 
execution. 

(BS)-«-0 
SEL RB1 Select Register Bank 1 (Not in 8021) 



110 1 10 1 



PSW bit 4 is set to one. References to working registers 
0-7 address data memory locations 24-31. This is the 
recommended setting for interrupt service routines, 
since locations 0-7 are left intact. The setting of 
PSW bit 4 in effect at the time of an interrupt is 
restored by the RETR instruction when the interrupt 
service routine is completed. 



(BS) 



1 



Example: 



Assume an external interrupt has occurred, control 
has passed to program memory location 3, and PSW bit 
4 was zero before the interrupt. 

LOC3: JNI INIT ;JUMP TO ROUTINE 'INIT IF 

INTERRUPT INPUT IS ZERO 
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INSTRUCTION SET 



INIT: MOV R7,A 

SEL RB1 
MOV R7,#0FAH 



MOVE ACC CONTENTS TO 

LOCATION 7 

SELECT REG BANK 1 

MOVE 'FA' HEX TO LOCATION 31 



SEL RBO 
MOV A.R7 
RETR 



SELECT REG BANK 

RESTORE ACC FROM LOCATION 7 

RETURN — RESTORE PC AND PSW 



STOP TCNT Stop Timer/Event-Counter 



110 10 1 



Example: 



This instruction is used to stop both time accumulation 
and event counting. 

Disable interrupt, but jump to interrupt routine after 
eight overflows and stop timer. Count overflows in 
register 7. 



START: 



MAIN: 



DIS TCNTI 
CLR A 
MOV T,A 
MOV R7,A 
STRTT 
JTF COUNT 



JMP MAIN 
COUNT: INC R7 

MOV A.R7 
JB3 INT 

JMP MAIN 



DISABLE TIMER INTERRUPT 

CLEAR ACC TO ZEROS 

MOVE ZEROS TO TIMER 

MOVE ZEROS TO REG 7 

START TIMER 

JUMP TO ROUTINE 'COUNT 

IF TF=1 AND CLEAR TIMER FLAG 

CLOSE LOOP 

INCREMENT REG 7 

MOVE REG 7 CONTENTS TO ACC 

JUMP TO ROUTINE 'INT IF ACC 

BIT 3 IS SET (REG 7=8) 

OTHERWISE RETURN TO ROUTINE 

MAIN 



INT: 



STOP TCNT 
JMP 7H 



STOP TIMER 

JUMP TO LOCATION 7 (TIMER) 

INTERRUPT ROUTINE 
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INSTRUCTION SET 



STRT CNT Start Event Counter 



100 10 1 



Example: 



The test 1 (T1) pin is enabled as the event-counter 
input and the counter is started. The event-counter 
register is incremented with each high-to-low transition 
on the T1 pin. 

Initialize and start event counter. Assume overflow 
is desired with first T1 input. 



STARTC: EN TCNTI 

MOV A,#0FFH 

MOV T,A 
STRT CNT 



ENABLE COUNTER INTERRUPT 

MOVE 'FF' HEX (ONES) TO 

ACC 

MOVE ONES TO COUNTER 

ENABLE T1 AS COUNTER 

INPUT AND START 



STRTT Start Timer 



10 1 10 1 



Timer accumulation is initiated in the timer register. 
The register is incremented every 32 instruction cycles. 
The prescaler which counts the 32 cycles is cleared 
but the timer register is not. 



Example: 



Initialize and start timer. 

STARTT: CLR A 

MOV T,A 
EN TCNTI 
STRTT 



CLEAR ACC TO ZEROS 
MOVE ZEROS TO TIMER 
ENABLE TIMER INTERRUPT 
START TIMER 



SWAP A Swap Nibbles Within Accumulator 



100 



111 



Bits 0-3 of the accumulator are swapped with bits 
4-7 of the accumulator. 

(A 4 _ 7 )^:(A _3) 
Example: Pack bits 0-3 of locations 50-51 into location 50. 



PCKDIG: 



MOV R0, #50 
MOV R1, #51 
XCHD A,@R0 

SWAP A 
XCHD A,@R1 

MOV @R0,A 



MOVE '50' DEC TO REG 

MOVE '51' DEC TO REG 1 

EXCHANGE BITS 0-3 OF ACC 

AND LOCATION 50 

SWAP BITS 0-3 AND 4-7 OF ACC 

EXCHANGE BITS 0-3 OF ACC AND 

LOCATION 51 

MOVE CONTENTS OF ACC TO 

LOCATION 50 
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INSTRUCTION SET 



XCH A,R r Exchange Accumulator-Register Contents 



10 



1 rr r 



The contents of the accumulator and the contents of 
working register 'r' are exchanged. 



(A)X (Rr) 



r=0-7 



Example: 



Move PSW contents to Reg 7 without losing 
accumulator contents. 
XCHAR7: XCH A,R7 



MOV A, PSW 
XCH A,R7 



EXCHANGE CONTENTS OF REG 7 
AND ACC 

MOVE PSW CONTENTS TO ACC 
EXCHANGE CONTENTS OF REG 7 
AND ACC AGAIN 



XCH A,@R r Exchange Accumulator and Data Memory Contents 



00 10 



00 r 



The contents of the accumulator and the contents of 
the resident data memory location addressed by bits 
0-5*of register Y are exchanged. Register 'r' 
contents are unaffected. 



(A)"X -((Rr)) 



r=0-1 



Example: Decrement contents of location 52. 

;MOVE '52' DEC TO ADDRESS 
;REG 

EXCHANGE CONTENTS OF ACC 
;AND LOCATION 52 



DEC52: MOV R0,#52 
XCH A,@R0 



DEC A 
XCH A,@R0 



DECREMENT ACC CONTENTS 
EXCHANGE CONTENTS OF ACC 
AND LOCATION 52 AGAIN 



XCHD A,@R r Exchange Accumulator and Data Memory 4-Bit Data 



00 11 OOOr 



This instruction exchanges bits 0-3 of the accumulator 
with bits 0-3 of the data memory location addressed by 
bits 0-5*of register Y. Bits 4-7 of the accumulator, 
bits 4-7 of the data memory location, and the contents 
of register 'r' are unaffected. 



(A n _ 3 )X((RrO-3)) 



r=0-1 



Mnemonics copyright Intel Corporation 1976. 
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INSTRUCTION SET 



Example: Assume program counter contents have been stacked in 
locations 22-23. 

XCHNIB: MOV R0,#23 ;MOVE '23' DEC TO REG 
CLR A ;CLEAR ACC TO ZEROS 

XCHD A,@R0 ;EXCHANGE BITS 0-3 OF ACC 
AND LOCATION 23 (BITS 8-11 
OF PC ARE ZEROED, ADDRESS 
REFERS TO PAGE 0) 

XRL A,R r Logical XOR Accumulator With Register Mask 



110 1 



1 r r r 



Data in the accumulator in EXCLUSIVE ORed with the mask 
contained in working register 'r\ 



(A)-«- (A) XOR (Rr) 
XORREG: XRL A,R5 



r=0-7 



Example 
XRL A,@R r Logical XOR Accumulator With Memory Mask 



;'XOR' ACC CONTENTS WITH 
;MASK IN REG 5 



110 1 



OOOr 



Data in the accumulator is EXCLUSIVE ORed with the mask 
contained in the data memory location addressed by 
register 'r\ bits 0-5! 

(A)-«- (A) XOR ((Rr)) r=0-1 



Example: XORDM: MOV R1, #20H 
XRLA,@R1 



MOVE '20' HEX TO REG 1 

'XOR' ACC CONTENTS WITH MASK 

IN LOCATION 32 



XRL A,#data Logical XOR Accumulator With Immediate Mask 



110 1 



11 



d7ded5d4 d3d2d-|do 



This is a 2-cycle instruction. Data in the accumulator 

is EXCLUSIVE ORed with an immediately-specified mask. 



Example: 



(A)-«- (A) XOR data 
XORID: XOR A,#HEXTEN 



XOR CONTENTS OF ACC WITH 
MASK EQUAL VALUE OF SYMBOL 
'HEXTEN' 



Mnemonics copyright Intel Corporation 1976. 
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APPLICATION EXAMPLES 



5.0 Introduction 

The following chapter is organized in two 
sections, Hardware and Software. The 
hardware section gives examples of some 
typical configurations of MCS-48 compon- 
ents while software section gives assembly 
language listings of some common appli- 
cations routines. 

5.1 Hardware Examples 



20pf 



20pf 



r 
I 



r 
I 



+5V 



XTAL1 



20pf Z= 



XTAL2 



1-6 MHz 

(TV COLOR BURST XTAL 
CAN BE USED) 

CRYSTAL 

NOTE: 

A STANDARD SERIES RESONANT XTAL SUCH 
AS CTS KNIGHTS MP060 OR CRYSTEK CY6B 
WILL PROVIDE BETTER THAN .1% FREQUEN- 
CY ACCURACY. 

IF HIGHER ACCURACY IS REQUIRED A 
PARALLEL RESONANT XTAL SHOULD BE 
SPECIFIED WHICH WILL OPERATE WITH A 
LOAD CAPACITANCE OF 20-25pf. FOR MORE 
INFORMATION ON XTALS SEE INTEL AP- 
PLICATION NOTE AP-35. 



20pf Z=. 



XTAL1 



-L> 



XTAL 2 




XTAL 1 



XTAL 2 



L=130mM=3MHz) . f 
L = 40ph (=*5MHz) n, 5 < 

f~2^7LC C = 10-15pf 
LC 



1-6 MHz 



EXTERNAL 



NOTE: SEE PAGE 5-3 FOR 8021 

FREQUENCY REFERENCES. 
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40 26 ,,20 



20pf 



20pf 



Vcc Vqd Vss 
XTAL 1 



RESET 



8049 
8048 
8748 



TO 
T1 
INT 



P10 
P11 
P12 
P13 
P14 
P15 
P16 
P17 

P20 
P21 
P22 
P23 
P24 
P25 
P26 
P27 

DBO 
DB1 
DB2 
DB3 
DB4 
DB5 
DB6 
DB7 



ALE PSEN PROG WR RD 



- PORT 1 



INPUT 

AND 

OUTPUT 



INPUT 

AND 

OUTPUT 



-BUS PORT 



' INPUT 

AND 

OUTPUT. 



11 9 25 10 



All inputs and outputs standard TTL compatible 
P1 and P2 outputs drive 5V CMOS directly others 
require 10 to 50KO pullup for CMOS compatibility 



XTAL: Series Resonant 
1 to 6 MHz 
or 

Parallel Resonant 
for higher 
accuracy 



CTS Knights MP060 
Crystek CY6B 
or equivalent 
or standard 3.58 MHz 
TV Color Burst XTAL 



THE STAND ALONE 8048/8049 
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1jifd. 
10V" 



DIODE 
OPTIONAL 



28 14 



5 



V cc V S s 

XTAL 1 



XTAL2 



8021 



POO 
P01 
P02 
P03 
P04 
P05 
P06 
P07 

P10 
P11 
P12 
P13 
P14 
P15 
P16 
P17 



P20 
P21 
P22 
P23 



ALE PROG 



> PORTO 



INPUT 

AND 

OUTPUT 



V PORT 1 



INPUT 

AND 

OUTPUT 



> PORT 2 



INPUT 

AND 

OUTPUT 



+5V 



Xi 



X 2 



1 MEGfi 



1K 



Xi 



X 2 



LC 



CRYSTAL 



-L> 

TTL 
GATE 



XTAL1 



XTAL 2 



NC* 



EXTERNAL 



ALTERNATE FREQUENCY REFERENCE OPTIONS 
(COMPONENT VALUES TO BE DETERMINED) 



THE STAND ALONE 8021 



APPLICATION EXAMPLES 



DEVICE 
1 



DEVICE 
2 



DEVICE 
3 



DEVICE 
4 



OPEN 
COLLECTOR 
INVERTERS 



>■ 



^ 



>► 



>* 



8049 
8048 
8748 
8035 
8039 



ANY 

UNDEDICATED 
PORT LINES 
CAN BE USED 



• All devices equal priority 

• Processor polls Port 1 to determine interrupting device 



MULTIPLE INTERRUPT SOURCES 
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INTERRUPT 
INPUTS 




o Processor polls Port 1 to determine interrupting device 
o Processor sets priority level by writing 4-bits to 8214 



MULTIPLE INTERRUPTS WITH PRIORITY LEVELS 
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40 ,26 .,20 



Vcc Vdd Vss 
XTAL1 



8049 

8048 

8748 

8035* 

8039* 



P10 

pii 

P12 
P13 
P14 
P15 
P16 
P17 

P20 
P21 
P22 
P23 
P24 
P25 
P26 
P27 

DBO 
DB1 
DB2 
DB3 
DB4 
DB5 
DB6 
DB7 



ALE PSEN PROG WR RD 



*EA=5V FOR 8035/8039 



Vcc GND 

8212 
LATCH 



Dh 
Dl 2 
Dl 3 
Dl 4 
Dl5 

Dl 6 

DI7 

Dl 8 
CLR 



DO1 
D0 2 
DO3 
DO4 
DO5 
D0 6 
DO7 
D0 8 



DS 2 MD DS, 

¥1 



+5V +12V 



Vdd Vbb 



Vss 



8708 
1Kx 8 
EPROM 



• 8212 serves as address latch 

• Address is valid while ALE is high and is latched 



when ALE goes low 
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+5V 



GND 



40 ,26 ,20 



NC 



Vcc Vqd Vss 
XTAL1 



SS 

TO 
T1 

INT 



8049 

8048 

8748 

8035* 

8039* 



P10 

P11 

P12 
P13 
P14 
P15 
P16 
P17 

P20 
P21 
P22 
P23 
P24 
P25 
P26 
P27 

DBO 
DB1 
DB2 
DB3 
DB4 
DB5 
DB6 
DB7 



ALE PSEN PROG WR RD 



25 10 



I/O 



I/O 



*EA = 5V FOR 8035/8039 



+5V 



CAN BE SUPPLIED BY SYSTEM 
RESET OR PORT LINE OF 8048 



40 



20 1 



Vcc Vqd Vss ce 



A8 
A9 
A10 

ADO 
AD1 
AD2 
AD3 
AD4 
AD5 
AD6 
AD7 

IOR 

iow 

RD 
ALE 
CE 
RESET 



8355 
8755A 
2Kx8 
ROM 



JI I 3 I 6 

"=" NC NC 



PAO 
PA1 
PA2 
PA3 
PA4 
PA5 
PA6 
PA7 

PBO 
PB1 
PB2 
PB3 
PB4 
PB5 
PB6 
PB7 



I/O 



External I/O parts are addressed as data memory PA=00 PB=01 
If the 8048's internal Program Memory is used this configuration will result in 
the upper 1K of external memory being addressed before the lower 1K. 
Inverting A10 will correct this if necessary. This inversion is not necessary if 
the 8049 is used. 
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+5V 



GND 



,40 J26 |20 




INPUTS 



Vcc Vqd Vss 
XTAL 1 



XTAL2 



SS 

TO 
T1 
JNT 



8049 

8048 

8748 

8035* 

8039* 



P10 
P11 
P12 
P13 
P14 
P15 
P16 
P17 

P20 
P21 
P22 
P23 
P24 
P25 
P26 
P27 

DBO 
DB1 
DB2 
DB3 
DB4 
DB5 
DB6 
DB7 



ALE PSEN PROG WR RD 



25 10 



32 



*EA = 5V FOR 8035/8039 



I/O 



CAN BE SUPPLIED BY SYSTEM 
RESET OR PORT LINE OF 8048 



ADO 
AD1 
AD2 
AD3 
AD4 
AD5 
AD6 
AD7 

IO/M 

RD 

WR 



GND 

20 



Vcc 



v S s 



8155 

256 x 8 

RAM 



RESET TIMER 
OUT 



TIMER 
IN 



TIMER 



PAO 
PA1 
PA2 
PA3 
PA4 
PA5 
PA6 
PA7 

PCO 
PC1 
PC2 
PC3 
PC4 
PC5 

PBO 
PB1 
PB2 
PB3 
PB4 
PB5 
PB6 
PB7 



- I/O 



Both I/O and RAM are addressed as data memory 
Writing a bit to P27 determines whether RAM or I/O is 
to be accessed 



ADDING A DATA MEMORY AND I/O EXPANDER 
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40 26 ,20 



OPTIONAL GATE 
TO PREVENT 
"HOLE" IN 
PROGRAM 
MEMORY 




Vcc Vdd Vss 
XTAL1 



8049 
8048 
8748 



TO 
T1 
INT 



ALE PSEN PROG WR RD 



P10 
P11 
P12 
P13 
P14 
P15 
P16 
P17 

P20 
P21 
P22 
P23 
P24 
P25 
P26 
P27 

DBO 
DB1 
DB2 
DB3 
DB4 
DB5 
DB6 
DB7 



x> 



CAN BE SUPPLIED BY SYSTEM 
RESET OR PORT LINE OF 8048 



+5V +5V GND GND 
40 5 20 1 



A8 
A9 
A10 

ADO 
AD1 
AD2 
AD3 
AD4 
AD5 
AD6 
AD7 

IOR 

IOW 

RD 

ALE 

CE 

RESET 



Vcc V D D Vss ce 



8355 

8755A 

2Kx8 

ROM 



I 



rr nc nc 



+5V 
40 



GND 
20 



Vcc 



v ss 



ADO 
AD1 
AD2 
AD3 
AD4 
AD5 
AD6 
AD7 



8156 

256 x 8 

RAM 



RESET TIMER 
OUT 



TIMER 
IN 



PA0 
PA1 
PA2 
PA3 
PA4 
PA5 
PA6 
PA7 

PBO 
PB1 
PB2 
PB3 
PB4 
PB5 
PB6 
PB7 



PAO 
PA1 
PA2 
PA3 
PA4 
PA5 
PA6 
PA7 

PCO 
PC1 
PC2 
PC3 
PC4 
PC5 

PBO 
PB1 
PB2 
PB3 
PB4 
PB5 
PB6 
PB7 



• This configuration is explained in section 3.4 



THE THREE CHIP SYSTEM 
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I/O Expansion Techniques 

The following are several examples of how 
the basic I/O capability of the MCS-48™ 
microcomputers can be easily expanded 
externally using either the 8243 I/O 



expander device or standard logic circuits. 
These techniques can be used whenever 
the combination memory/IO expanders 
illustrated on the preceeding pages are not 
required. 



+5V 



GND 



,40 ,26 ,20 



INPUT 



Vcc VqD Vss 
XTAL1 



XTAL2 



RESET 

EA 

SS 

TO 
T1 
fNT 



8049 
8048 
8748 
8035 
8039 



P10 
P11 
P12 
P13 
P14 
P15 
P16 
P17 

P20 
P21 
P22 
P23 
P24 
P25 
P26 
P27 

DB0 
DB1 
DB2 
DB3 
DB4 
DB5 
DB6 
DB7 



ALE PSEN PROG WR RD 



I/O 



- I/O 



Vcc 



8243 

I/O 

EXPANDER 



P20 
P21 
P22 
P23 

PROG 

CS 



P40 
P41 
P42 
P43 

P50 
P51 
P52 
P53 

P60 
P61 
P62 
P63 

P70 
P71 
P72 
P73 



I/O 



ADDING AN I/O EXPANDER 
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+5V GND 



28 14 



1jjfd. 
10V 



DIODE -T*r- 

OPTIONAL A 



Vcc Vss 

XTAL 1 



8021 



ALE PROG 



POO 
P01 
P02 
P03 
P04 
P05 
P06 
P07 

P10 
P11 
P12 
P13 
P14 
P15 
P16 
P17 



P20 
P21 
P22 
P23 



Vcc 



8243 

I/O 

EXPANDER 



P20 
P21 
P22 
P23 

PROG 

CS 



P40 
P41 
P42 
P43 

P50 
P51 
P52 
P53 

P60 
P61 
P62 
P63 

P70 
P71 
P72 
P73 



- I/O 
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Vcc Vqd Vss 

XTAL1 



8049 
8048 
8748 
8035 
8039 
8021* 



TO 
T1 
[NT 



+5V 

24 



GND 
12 



ALE PSEN PROG WR RD 



P10 
P11 
P12 
P13 
P14 
P15 
P16 
P17 

P20 
P21 
P22 
P23 
P24 
P25 
P26 
P27 

DBO 
DB1 
DB2 
DB3 
DB4 
DB5 
DB6 
DB7 



I/O 



*PIN NUMBERS ARE DIFFERENT FOR 8021 



! I 



Vcc 



8243 

I/O 

EXPANDER 



P20 
P21 
P22 
P23 



+5V 
24 



GND 

12 



Vcc 



8243 

I/O 

EXPANDER 



P20 
P21 
P22 
P23 



' ' ' , 

I I I I I 
I I I I I 



P40 
P41 
P42 
P43 

P50 
P51 
P52 
P53 

P60 
P61 
P62 
P63 

P70 
P71 
P72 
P73 



-I/O 



P40 
P41 
P42 
P43 

P50 
P51 
P52 
P53 

P60 
P61 
P62 
P63 

P70 
P71 
P72 
P73 



-I/O 
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Vcc V DD Vss 
XTAL 1 



8049 
8048 
8748 



P22 
P23 
P24 
P25 
P26 
P27 

DBO 
DB1 
DB2 
DB3 
DB4 
DB5 
DB6 
DB7 



ALE PSEN PROG WR RD 




VA 'NO 

VA IN1 

-VV\ IN2 

VA IN3 

VA IN4 

VA IN5 

-VVV IN6 



The bus is normally used as an output port. To 
use it as an input port the bus is put in the high 
impedance state using the MOVX instruction 
and then read using the INS instruction. The 
resistor value chosen is a function of the 
output loading and the characteristics of the 
input signals. 



ADDING 8 INPUT LINES 



Vcc Vdd Vss 
XTAL 1 



8049 
8048 
8748 



P22 
P23 
P24 
P25 
P26 
P27 

DBO 
DB1 
DB2 
DB3 
DB4 
DB5 
DB6 
DB7 



ALE PSEN PROG WR RD 



s=- 



-£=- 



74LS259 
116) 



Individual bits of the 74LS259 eight-bit 
addressable latch can be set or reset using the 
OUTL instruction. During the OUTL operation 
bit zero of the accumulator is written into the 
bit of the latch specified by bits 1 through 3 of 
the accumulator. In this configuration DBo- 
DB7 will be momentarily disturbed while the 
external latch is loaded. 



ADDING 8 OUTPUT LINES 
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VcC Vdd Vss 
XTAL 1 





P12 




P13 




P14 




P15 




P16 




P17 


8049 
8048 


P20 
P21 


8748 


P22 


8021* 
8035 
8039 


P23 

P24 
P25 
P26 




P27 




DBO 




DB1 




DB2 




DB3 




DB4 




DB5 




DB6 




DB7 



ALE PSEN PROG WR RD 



4H- 



74150 
124) 



Normal I/O port is used to select an address 
for the 16-to-1 multiplexer. The output of the 
multiplexer is brought into a test input. Eight 
inputs could be added with a 74LS151 8-to-1 
multiplexer using the same structure. 



Note: If external program memory is being 
addressed, use P24-P27 instead of P20-P23. 



•PIN NUMBERS ARE DIFFERENT FOR 8021 



ADDING 16 INPUT LINES 



Vcc v D d Vss 
XTAL 1 



8049 
8048 
8748 



ALE PSEN PROG WR RD 



P22 
P23 
P24 
P25 
P26 
P27 

DBO 
DB1 
DB2 
DB3 
DB4 
DB5 
DB6 
DB7 



The latch can be loaded with the OUTL 
instruction. After the latch is loaded the BUS 
output state can be modified with the ANL 
BUS, # DATA and the ORL BUS, # DATA. The 
OUTL generates a WR strobe; ANL and ORL 
do not. In this configuration DB0-DB7 will be 
momentarily disturbed while the external latch 
is loaded. 



-£=- 



74LS174 
(16) 



ADDING 6 OUTPUT LINES 



5-14 



APPLICATION EXAMPLES 



+5V GND 



V CC V S S 

XTAL 1 



8049 

8048 

8748 

8021* 

8035 

8039 



ALE PROG 



DISPLAY 

AND/OR 

KEYBOARD 

ARRAY 



This is most useful when the outputs of the 
74LS164 eight-bit shift register will be used to 
scan a display and/or keyboard. In this case an 
ANLD P7, A with A = OFFH can be used to load 
the initial "1 " and an ANLD P6, A with A = OFEH 
can be used to move it down the shift register. 



QA O.B QC QD QE QF QG OH 



74LS164 
(14) 



•PIN NUMBERS ARE DIFFERENT FOR 8021 
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NOTE: 

P 2 3 IS SHOWN 
HERE CONNECTED 
FOR OUTPUT; P 22 
IS CONNECTED 
FOR INPUT. 




8049 EMULATOR CIRCUIT 
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8049 EMULATOR CIRCUIT DESCRIPTION 

The following is an explanation of a circuit which 
emulates the operation of an Intel® 8049 using a stan- 
dard EPROM for program storage. 

With the 8049, software may be developed by running 
external program memory, but doing so requires the use 
of the bus and P23-P20 t0 access this memory. 
The circuit shown may be used to restore the normal 
functioning of these twelve I/O pins. The circuit con- 
sists of an 8039 CPU, 2716 EPROM, two 8216 bi- 
directional bus drivers, and eight other 7400 Series Low- 
Power Schottky TTL packages. The whole assembly can 
be built on a 2-3/4" x 4" board. 

A cable coming off the board can be terminated by a 
forty-pin plug which may be inserted directly into the 
CPU socket intended for the 8049 in a system undergo- 
ing design or testing. Alternatively, a pattern of forty 
pins extending below the board can be used to plug the 
board directly into the system undergoing testing, 
"piggy-back" fashion. The emulator board may be con- 
figured in various ways so that the 40 pin plug is the 
logical equivalent of an 8049 in every legal operating 
mode. (In the following explanation of the operation of 
the circuit, an ast erisk a ppearing before a signal or pin 
number — as in *PSEN — refers to that pin on the "vir- 
tual 8049" represented by the forty-pin plug). 

Since the CPU is identical with the 8049 in all respects 
other than its lack of program memory, most of the pins 
of the 8039 are simply connected directly to the cor- 
responding pins of the forty-pin plug. These include all 
of Port 1, the high order bits of Port 2, the test pins, etc. 
Signals which are emulated with additi onal log i c in- 
elude the rest o f Port 2, DB 7 -DB , *PSEN, etc. RD, WR, 
ALE, and PSEN are obtained from the 8039, but are also 
used by the emulation circuitry. 

The EA input of the 8039 is hard-wired high so all in- 
struction fetches are made from the 2716. Two 74LS75 
four-bit latches gated by the buffered ALE signal are 
used to hold the lower eight bits of address from the 
time-multiplexed data bus. Since the Bus is being used 
for fetching instructions, data latched to the Bus will be 
lost on the next instruction fetch. Two 74LS174 latches 
are used to retain the output data when a bus write is 
executed. These latches are triggered by the trailing 
edge of the WR pulse, so their outputs are glitch free. 
Since logical operations to the bus do not generate a 
WR strobe, the "ANL BUS,#" and "ORL BUS,#" instruc- 
tions may not be used, though they do function properly 
with the other ports. 

The two 8216 bi-directional bus drivers normally buffer 
the latched bus contents to the DB pins of the virtual 
8049. When an "INS A.BUS" instruction is executed, 
they buffer the input signals on to the emulator data 
bus. Thus, the circuit is designed to use the Bus for both 
latched output and strobed input. If DB79DB0 of the 
8049 are to be used solely for input data, J2 and J3 may 



be changed from what is shown in the Figure, so that 
DB7-DB0 act as high impedance inputs and the 8216s 
are enabled only when the read operation is performed. 
If the bus is to be used only for latched output, the 
8216s can be omitted entirely. 

Bi-directional data transfers which require the transfer 
of address information as well as data, such as to and 
from external data memory, require removal of the 
8216s and replacement with 16-pin jumper blocks on 
which the DB X pins are connected with the respective 
DO x pins. 

The lower four bits of Port 2 are also used in fetching in- 
structions from the 2716, in addition to their use as in- 
put or output pins in the user's system. In configuring 
the emulator for a particular application, the user must 
dedicate each of these as either an input or output pin 
and connect jumper set J1 accordingly. Any mix of input 
and output pins is allowed. At the beginning of each in- 
struction fetch, the last data written to P2 will be pre- 
sent on P23-P20 at the rising edge of ALE and will be 
latched by a 74LS174. The latched data may be con- 
nected through the jumpers to those pins which will be 
used as outputs on the 8049. Emulator pins used as in- 
puts should be pulled above 2.0V for a logic "one". If 
this is not the case, i.e., if switches to Ground are to be 
read, 50K pullup resistors should be added to the circuit 
on each input. They were omitted from the diagram to 
minimize input loading. 

Pins which will be used as inputs may be connected to 
the input of an OR gate formed of inverters and open- 
collector NAND gates. The input signals will be relayed 
directly to the 8039 and w ill be read by an "IN A,P2" in- 
struction. But when PSEN is low, the NAND outputs are 
forced off, allowing the 8039 pins to be used for high- 
order program adressing. Open-collector outpu ts are 
needed to prevent line contention when PSEN is not 
low. 

If 8243s will be be used in the final system, the low order 
pins of Port 2 must be connected directly to the plug. 
This may be done by replacing the Port 2 latch with four 
jumpers connecting the inputs to the outputs. The 
NANDs should be removed or disabled by grounding the 
common NAND inputs. 

The cluster of three OR gates is used t o enable the on- 
board 2716 and gen erate t he *PSEN signal, each of 
which is a function of PSEN, * EA, an d the high order bit 
of the program counter. Thus *PSEN is generated, forc- 
ing an off-board read, only when a jump has been made 
to Memory Bank 1 or when *EA is brought high. If this 
feature is to be used to address off-board memory, DB 7 - 
DB may not be used for normal I/O. The 8216s and 
74LS174 must be replaced with jumper blocks and the 
open collector NAND gates disabled, as explained 
above. The same changes are required to operate the 
board in single step mode. 
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APPLICATION EXAMPLES 



PRINTER POS. 



V 



DRUM PRINTER* 



RDY/BSY' 
•SEIKO =101 



PORT 1 PORT 1 

8048 

BUS 



7\ 



DATA IN OR 8080 INTERNAL BUS 



8048 INTERFACE TO DRUM PRINTER 



1000 PULSE/GAL. 




MCS-48™ GAS PUMP 
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APPLICATION EXAMPLES 



CASH DRAW 

KEY SWITCH 

TOTALS 

AUDIO INDICATOR 



:> 






8748/8048 
PROM/ROM 

RAM 
I/O TIMER 



A 
V 



INTERRUPT 



DATA 8. STROBE 
STEPPER MOTOR 
CONTROL 
PAPER ADVANCE 
STATUS 



12 



MATRIX PRINTER* 

WITH PAPER 

ADVANCE 



~7\ 



±1 



TO OPTIONAL 

• COMMUNICATIONS 
INTERFACE 

• READER 

• STORE AND FORWARD 



8279 
KEYBOARD DISPLAY 



SCAN LINES 



12 



CASH REGISTER KEYBOARD 

• NUMERIC 

• DEPT. 

• ITEM 

• TAX 

• ETC. 



iz 



FRONT AND 
REAR DUAL 
DISPLAY 



Q SEVEN 

U U SEGMENT 



INDICATOR LAMP MATRIX FOR 
ILLUMINATED KEY TOPS 




•DRUM PRINTER MAY BE USED. 
DRUM PRINTER REQUIRES 
MORE OUTPUTS WHICH CAN BE 
OBTAINED FROM AN EXPANDER 
DEVICE. 



LOW COST POINT OF SALE TERMINAL 
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OXYGEN 
SENSOR 
(I OR O) 



H> 



IGNITION 
PULSE 
(ENGINE SPEEDI 



OPEN LOOP MODES 

WIDE OPEN 

COLD ENGINE 

DECELERATE 

ENGINE CRANKING 



} 



I — Wv — | 



XTAL1 XTAL2 



c 



VEHICLE TYPE 
IDENTIFICATION 



\ DARLII 

y\ dri> 




POWER TRAIN 
TYPE IDENTIFICATION 



SIMPLE FEEDBACK CARBURETOR CONTROLLER 



POWER 
SUPPLY 



MAGNETRON 
TRIAC 



DOOR 
INTERLOCK 



60Hz 

TIMING 

REFERENCE 



FRONT PANEL 

4x4 

KEYBOARD 



Vcc 



A 



STATUS 
INDICATORS 



UU'UU 
I II 1,1 II I 



MICROWAVE OVEN CONTROLLER 
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APPLICATION EXAMPLES 



5.2 Software Examples 



The following routines are written as subroutines. RO and R1 are 
used as data pointers, R2 is used as an extension of the accumulator 
and R3 is used as a loop counter. 



RXO = RO 
AEX = R2 



DOUBLE ADD 



DADD: 



DEC 

ADD 

INC 

XCH 

ADDC 

XCH 

RET 



RXO 

A,@RX0 

RXO 

A.AEX 

A,@RX0 

A.AEX 



DOUBLE SUBTRACT 



DMIN: DEC 
CPL 
ADD 
CPL 
INC 
XCH 
CPL 
ADDC 
CPL 
XCH 
RET 

DOUBLE LOAD 

DLD: DEC 
MOV 
INC 
XCH 
MOV 
XCH 
RET 

DOUBLE STORE 



DST: 



DEC 

MOV 

INC 

XCH 

MOV 

XCH 

RET 



RXO 

A 

A,@RX0 

A 

RXO 

A.AEX 

A 

A,@RX0 

A 

A.AEX 



RXO 

A,@RX0 

RXO 

A.AEX 

A,@RX0 

A, AEX 



RXO 

@RX0,A 

RXO 

A.AEX 

@RX0,A 

A.AEX 



;GET LOW BYTE AND ADD TO A 
;GET HI BYTE AND ADD TO AEX 

;RETURN 

;GET LOW BYTE AND SUB FROM A 

;GET HI BYTE AND SUB FROM AEX 



;RETURN 

;GET LOW BYTE AND PLACE IN A 
;GET HI BYTE AND PLACE IN AEX 

;RETURN 

;MOVE A INTO LOW BYTE 
;MOVE AEX INTO HIGH BYTE 

;RETURN 



APPLICATION EXAMPLES 



DOUBLE 

DEX: 



EXCHANGE 

RXO 



DEC 

XCH 

INC 

XCH 

XCH 

XCH 

RET 



A,@RX0 

RXO 

A.AEX 

A,@RX0 

A.AEX 



;EXCHANGE A AND LOW BYTE 
;EXCHANGE AEX AND HIGH BYTE 



DOUBLE 

LLSH: 



;RETURN 
LEFT LOGICAL SHIFT 



RLC 
XCH 
RLC 
XCH 
RET 



A 

A.AEX 
A 
A.AEX 



;SHIFT A 
;SHIFT AEX 



DOUBLE 

RLSH: 



;RETURN 
RIGHT LOGICAL SHIFT 

;SHIFT AEX 



XCH 
RRC 
XCH 
RRC 
RET 



A.AEX 
A 

A.AEX 
A 



;SHIFT A 
;RETURN 



DOUBLE 

RASH: 



RIGHT ARITHMETIC SHIFT 

;SET CARRY 



CLR 
CPL 

XCH 

JB7 

CLR 

RRC 

XCH 

RRC 

RET 



C 
C 

A,AEX 

$+3 

C 

A 

A,AEX 

A 



;IF AEX[7]<>1 THEN 

;CLEAR CARRY 
;SHIFT C INTO AEX 

;SHIFT A 
;RETURN 



SINGLE PRECISION BINARY MULTIPLY 

This routine assumes a one-byte multiplier 
and a one-byte multiplicand. The product, 
therefore, is two-bytes long. 

The algorithm follows these steps: 

1. The registers are arranged as follows: 

ACC — 

R1 — Multiplier 

R2 — Multiplicand 

R3 — Loop Counter (=8) 
The Accumulator and register R1 are 
treated as a register pair when they are 
shifted right (see Step 2) 



2. The Accumulator and R1 are shifted 
right one place, thus the LSB of the 
multiplier goes into the carry. 

3. The multiplicand is added to the 
accumulator if the carry bit is a 'one'. No 
action if the carry is a 'zero'. 

4. Decrement the loop counter and loop 
(return to Step 2) until it reaches zero. 

5. Shift the result right one last time just 
before exiting the routine 

*The result will be found in the Accumulator 
(MS Byte) and R1 (LS Byte). 
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BINARY MULTIPLY 

BMPY: MOV R3,#08H 



BMPI: 



BMP3: 



CLR 


A 


CLR 


C 


RRC 


A 


XCH 


A,R1 


RRC 


A 


XCH 


A,R1 


JNC 


BMP3 


ADD 


A,R2 


DJNZ 


R3.BMPI 


RRC 


A 


XCH 


A,R1 


RRC 


A 


XCH 


A,R1 



SET COUNTER TO 8 

CLEAR A 

CLEAR CARRY BIT 

DOUBLE SHIFT RIGHT ACC & R1 
INTO CARRY 



IF CARRY=1 ADD, OTHERWISE DON'T 
ADD MULTIPLICAND TO ACCUMULATOR 

DECREMENT COUNTER AND LOOP IF 
DO A FINAL RIGHT SHIFT AT THE 
END OF THE ROUTINE 



INTERRUPT HANDLING 

This interrupt routine assumes single level 
interrupt. The purpose is to store the status of 
the machine at the time the interrupt occurs 
by storing contents of all registers, accumu- 
lator, and the status word. At the end of the 
interrupt the state of the machine is restored 
and interrupts are enabled again. 



INTRPT: SEL 
MOV 



i 
i 

MOV 
MOV 
RETR 



RB1 ;SAVE WORKING REGISTERS 

@R0,A ;R0 IN ALTERNATE REGISTER 
BANK CONTAINS SACC 
POINTER FOR SAVING 
ACCUMULATOR 

| /INTERRUPT SERVICE 

i 1R° UTINE 

RO.SACC ;RESTORE SACC 

A,@R0 ;RESTORE ACCUMULATOR 

RESTORE WORKING REGISTERS 
RESTORE PSW AND 
RE-ENABLE INTERRUPTS 



APPLICATION EXAMPLES 



2 BYTE PROCESSING SYSTEM 

A suggested model of a processing routine 
takes two single byte inputs from different 
ports, compares them, and performs the 
following, depending on the result of the 
comparison: 



(If Equal) Sets Flag and Exits 
(If Not Equal) Resets Flag and Outputs the 
Larger to a Third Port 



INPUT FIRST OPERAND 
INPUT SECOND OPERAND 





EQUAL / ^ ^ 


>ARE ^ 


NOT EQUAL 






' 






^ 


1 


SETFO 


2ND S 


WHICH \ 1ST 












IS } 

LARGER? / 












■ 






" 






OUTPUT 2ND 






OUTPUT 1ST 


























' ' 










RESET FO 























CrD 



PROCESS: CLR 
IN 

MOV 
IN 

MOV 
CPL 
INC 
ADD 
JNC 

X JB7 

MOV 
OUTL 
JMP 

SECOND: MOV 

OUTL 

JMP 

EQUL: CPL 

JMP 



FO 

A,P1 

R0,A 

A,P2 

R1,A 

A 

A 

A,R0 

EQUL 

SECOND 

A,R0 

BUS.A 

DONE 

A,R1 

BUS.A 

DONE 

FO 

DONE 



;CLEAR FO BIT (INITIALIZE) 

;READ FIRST INPUT, STORE IN RO 

;READ SECOND INPUT, STORE IN R1 

SUBTRACT SECOND FROM FIRST 
;(2's COMPLEMENT AND ADD) 

BRANCH IF THEY ARE EQUAL 

IF NEGATIVE, SECOND WAS LARGER 

ELSE, OUTPUT FIRST 

;EXIT 

;OUTPUT SECOND 

EXIT 

SETFO 

EXIT 



APPLICATION EXAMPLES 



A/D CONVERTER 

An A/D converter can be constructed from a 
D/A converter, a comparator op-amp and a 
short software routine that performs succes- 
sive approximation. 

The processor sends 8-bits of data out to the 
DAC via an output port. The output of the 
DAC is compared to the analog input being 
converted. The result of the comparison (0 if 



lower, 1 if higher) then goes back into the 
processor for handling either via an input 
port or an input line that sets a flag. This all 
allows the processor to estimate the proper 
digital representation of the analog input by 
first typing the MSB — and keeping it if the 
input says 'too low still' or dropping it if the 
input says 'too high now'. From there each bit 
in order of significance is tried and either kept 
or discarded. 



MOV 

CLR 

MOV 

MOV 

CLR 

CPL 

LOOP: MOV 
RRC 
MOV 
ORL 
OUTL 
JTO 

MOV 
NOPE: DJNZ 



R7,#08H 

A 

R5,A 

R6,A 

C 

C 

A,R5 

A 

R5.A 

A,R6 

P1,A 

NOPE 

R6,A 
R7.LOOP 



;COUNTER R7=8 
;CLEAR A, R5, R6 



;SET CARRY 

;MOVETEST BIT RIGHT 
:FROM MSB TO LSB 

;ADD IT TO PRESENT VALUE IN R6 

TEST THAT NEW VALUE 
IF FLAG IS HIGH NEW VALUE TOO LARGE 
IF FLAG LOW, NEW VALUE RETAINED 
GO ON TO NEXT BIT 

























V|N 




/ 


D/A 












>8 








8048 








V 2 








\- 


/ 






\ 


/OP-AMP OUTPUT 






\ 


r 0IFV 2 <V| N 
1 IFV 2 >V| N 






I 
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MCS-48XOMPONENT SPECIFICATIONS' 




MCS-48™ COMPONENT SPECIFICATIONS 



8048 ROM Microcomputer 6-1 

8648 EPROM Microcomputer 6-1 

8748 EPROM Microcomputers 6-1 

8035 Microcomputers 6-1 

8049/8039/ 

8039-6 Microcomputers 6-9 

8021 Microcomputer 6-15 

8022 Microcomputer 6-21 

8355 ROM and I/O Expander 6-33 

8755 EPROM and I/O Expander 6-39 

8155/8156 RAM and I/O Expander 6-45 

8243 MCS-48™ I/O Expander 6-57 



Intel 



8048/8648/8748/8035 
SINGLE COMPONENT 8-BIT MICROCOMPUTER 

• 8048 Mask Programmable ROM 

• 8648 One-Time Factory Programmable EPROM 

• 8748 User Programmable/Erasable EPROM 

• 8035 External ROM or EPROM 



8-Bit CPU, ROM, RAM, I/O in 
Single Package 

Interchangeable ROM and EPROM 
Versions 

Single 5V Supply 

2.5 jusec and 5.0 /usee Cycle Versions: 
All Instructions 1 or 2 Cycles 

Over 90 Instructions: 70% Single Byte 



1Kx 8ROM/EPROM 
64 x 8 RAM 
27 I/O Lines 

Interval Timer/Event Counter 

Easily Expandable Memory and I/O 

Compatible with 8000 Series Peripherals 

Single Level Interrupt 



The Intel® 8048/8648/8748/8035 is a totally self-sufficient 8-bit parallel computer fabricated on a single silicon chip 
using Intel's N-channel silicon gate MOS process. 

The 8048 contains a 1 K x 8 program memory, a 64 x 8 RAM data memory,27 I/O lines, and an 8-bit timer/counter in addition 
to onboard oscillator and clock circuits. For systems that require extra capability, the 8048 can be expanded using 
standard memories and MCS-80™ (8080A) peripherals. The 8035 is the equivalent of an 8048 without program memory. 
The 8035L has the RAM power down mode of the 8048 while the 8035 does not. 

To reduce development problems to a minimum and provide maximum flexibility, three interchangeable pin-compatible 
versions of this single component microcomputer exist: the 8748 with user-programmable and erasable EPROM program 
memory for prototype and preproduction systems, the 8048 with factory-programmed mask ROM program memory for 
low cost, high volume production, and the 8035 without program memory for use with external program memories. 

This microprocessor is designed to be an efficient controller as well as an arithmetic processor. The 8048 has extensive bit 
handling capability as well as facilities for both binary and BCD arithmetic. Efficient use of program memory results from 
an instruction set consisting mostly of single byte instructions and no instructions over 2 bytes in length. 



PIN CONFIGURATION 



LOGIC SYMBOL 



BLOCK DIAGRAM 



TOC 
XTAL iC 
XTAL 2C 
RESfTC 

ssC 
intC 
eaC 
rdC 
psenC 
WrC 
aleC 
DB oC 

DB,C 
DB 2 £ 
DB 3 C 
DB 4 C 

db 5 [i 

DB 6 C 
DBjC 
v ssC 



9 8048 

io 8648 

11 8748 

12 8035 

13 



i nv cc 

39 HT1 
38 JP27 
37 |]P26 
36 HP25 
35 I]P24 
34 Dpi? 
33 I] P16 
32 3P15 
31 DP14 
30 ]P13 
29 DP12 
28 I)P11 
27 JP10 
26 IJV DD 
25 3 PROG 
24 DPM 
23 I]P22 
22 HP21 
21 DP20 



><A> 



8048 



0>5" 



<a>: 



PROGRAM 
► STORE 
ENABLE 

ADDRESS 
- LATCH 
ENABLE 



PORT 
-EXPANDER 
STROBE 



8-BIT 
CPU 



1024 WORDS 
PROGRAM 
MEMORY 



7\ 



64 WORDS 

DATA 
MEMORY 



7\ 



<Z 



8-BIT 

TIMER/ 

EVENT COUNTER 



sz 



6-1 



8048/8648/8748/8035 



PIN DESCRIPTION 

Designation Pin # Function 



Vc 



Vcc 
PROG 



P10-P17 


27-34 


Port 1 




P20-P27 


21-24 


Port 2 


35-38 



DB -DB- 
BUS 



TO 



T1 



INT 



20 Circuit GND potential 

26 Programming power supply; +25V 

during program, +5V during oper- 
ation for both ROM and PROM. 
Low power standby pin in 8048 
ROM version. 

40 Main power supply; +5V during 

operation and programming. 

25 Program pulse (+25V) input pin 

during 8748 programming. 

Output strobe for 8243 I/O 
expander. 

8-bit quasi-bidirectional port. 

8-bit quasi-bidirectional port. 

P20-P23 contain the four high 
order program counter bits during 
an external program memory fetch 
and serve as a 4-bit I/O expander 
bus for 8243. 

12-19 True bidirectional port which can 
be written or read synchronously 
using the RD, WR strobes. The 
port can also be statically latched. 

Contains the 8 low order program 
counter bits during an external 
program memory fetch, and receives 
the addres sed ins truction under the 
control of PSEN. Also contains the 
address and data during an external 
RAM data store instructi on, u nder 
control of ALE, RD, and WR. 

1 Input pin testable using the con- 

ditional transfer instructions JT0 
and JNT0. TO can be designated as 
a clock output using ENT0 CLK 
instruction. TO is also used during 
programming. 

39 Input pin testable using the JT1, 

and JNT1 instructions. Can be des- 
ignated the timer/counter input using 
the STRT CNT instruction. 

6 Interrupt input. Initiates an inter- 

rupt if interrupt is enabled. Inter- 
rupt is disabled after a reset. Also 
testable with conditional jump 
instruction. (Active low) 



Designation Pin # Function 



RD 



RESET 



WR 



ALE 



PSEN 



SS 



EA 



XTAL1 



XTAL2 



8 Output strobe activated during a 
BUS read. Can be used to enable < 
data onto the bus from an external 
device. 

Used as a read strobe to external 
data memory. (Active low) 

4 Input which is used to initialize the 
processor. Also used during PROM 
programming verification, and 
power down. (Active low) 
(NonTTL V| H ) 

10 Output strobe during a bus write. 
(Active low) 

Used as write strobe to external 
data memory. 

11 Address latch enable. This signal 
occurs once during each cycle and 
is useful as a clock output. 

The negative edge of ALE strobes 
address into external data and pro- 
gram memory. 

9 Program store enable. This output 
occurs only during a fetch to exter- 
nal program memory. (Active low) 

5 Single step input can be used in con- 
junction with ALE to "single step" 
the processor through each in- 
struction. (Active low) 

7 External access input which forces 

all program memory fetches to re- 
ference external memory. Useful 
for emulation and debug, and 
essential for testing and program 
verification. (Active high) 

2 One side of crystal input for inter- 
nal oscillator. Also input for exter- 
nal source. (Non TTL Vm ) 

3 Other side of crystal input. 
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INSTRUCTION SET 



Mnemonic Description 



Bytes Cycle 



Description 



Bytes Cycles 



ADD A, R 
ADD A, @R 
ADD A, #data 
ADDC A, R 
ADDC A, @R 
ADDC A, #data 
ANLA, R 
AN LA, @R 
ANLA, #data 
ORLA,R 
ORL A, @R 
OR LA, #data 
XRLA,R 
XRLA, @R 
XRL A, #data 
INC A 
DEC A 
CLR A 
CPLA 
DA A 
SWAP A 
RLA 
RLC A 
RR A 
RRCA 



Add register to A 

Add data memory to A 

Add immediate to A 

Add register with carry 

Add data memory with carry 

Add immediate with carry 

And register to A 

And data memory to A 

And immediate to A 

Or register to A 

Or data memory to A 

Or immediate to A 

Exclusive or register to A 

Exclusive or data memory to A 

Exclusive or immediate to A 

Increment A 

Decrement A 

Clear A 

Complement A 

Decimal adjust A 

Swap nibbles of A 

Rotate A left 

Rotate A left through carry 

Rotate A right 

Rotate A right through carry 



IN A, P 
OUTLP, A 
ANL P, #data 
ORL P, #data 
INS A, BUS 
OUTLBUS.A 
ANL BUS,#data 
ORL BUS,#data 
MOVD A, P 
MOVD P, A 
ANLD P, A 
ORLD P, A 



Input port to A 
Output A to port 
And immediate to port 
Or immediate to port 
Input BUS to A 
Output A to BUS 
And immediate to BUS 
Or immediate to BUS 
Input expander port to A 
Output A to expander port 
And A to expander port 
Or A to expander port 



fe I NCR 
2 INC @R 
J" DECR 



Increment register 
Increment data memory 
Decrement register 





JMPaddr 


Jump unconditional 


2 


2 




JMPP @A 


Jump indirect 


1 


2 




DJNZR, addr 


Decrement register and skip 


2 


2 




JCaddr 


Jump on carry = 1 


2 


2 




JNCaddr 


Jump on carry = 


2 


2 




J Z addr 


Jump on A zero 


2 


2 




JNZaddr 


Jump on A not zero 


2 


2 


.c 
u 


JTO addr 


Jump on TO = 1 \ 


2 


2 


n 


JNTOaddr 


Jump on TO = ^ 


x 2 


2 


03 


JT1 addr 


Jump on T1 = 1 


V 2 


2 




JNT1 addr 


Jump on T1 = 


-2 


2 




JFOaddr 


Jump on FO = 1 


2 X \ 


2 




JF1 addr 


Jump on F1 = 1 


2 


2 




JTF addr 


Jump on timer flag 


2 


2 




JNI addr 


Jump on INT= 


2 


2 




JBbaddr 


Jump on accumulator bit 


2 


2 



^c 


CALL 


Jump to subroutine 2 


2 


3 



RET 


Return 1 


2 


.a 

3 
CO 


RETR 


Return and restore status 1 


2 




CLR C 


Clear carry 1 






CPL C 


Complement carry 1 




O) 


CLR FO 


Clear flag 1 




Li. 


CPL FO 


Complement flag 1 






CLR F1 


Clear flag 1 1 






CPL F1 


Complement flag 1 1 






MOV A, R 


Move register to A 1 






MOV A, @R 


Move data memory to A 1 






MOV A, #data 


Move immediate to A 2 






MOV R, A 


Move A to register 1 






MOV @R, A 


Move A to data memory 1 






MOV R, #data 


Move immediate to register 2 




0> 

> 


MOV@R,#data 


Move immediate to data memory 2 




o 


MOV A, PSW 


Move PSW to A 1 




ra 


MOV PSW, A 


Move A to PSW 1 




Q 


XCH A, R 


Exchange A and register 1 






XCHA,@R 


Exchange A and data memory 1 






XCHD A, @R 


Exchange nibble of A and register 1 






MOVX A, @R 


Move external data memory to A 1 


2 




MOVX @R, A 


Move A to external cl;it;i memory 1 


2 




MOVP A, @A 


Move to A from current p;igo 1 


2 




MOVP3 A, @A 


Move to A from pogo 3 1 


2 




MOV A, T 


Read timer/counter 1 




a> 


MOV T, A 


Load timer/counter 1 




3 


STRTT 


Start timer 1 




u 


STRT CNT 


Start counter 1 




a> 


STOP TCNT 


Stop timer/counter 1 




E 


ENTCNTI 


Enable timer/counter interrupt 1 




DISTCNTI 


Disable timer/counter interrupt 1 






EN I 


Enable external interrupt 1 






DISI 


Disable external interrupt 1 







SELRB0 


Select register bank 1 




c 


SELRB1 


Select register bank 1 1 




O 


SEL MBO 


Select memory bank 1 






SEL MB1 


Select memory bank 1 1 






ENT0CLK 


Enable clock output on TO 1 





NOP 



No operation 



Mnemonics copyright Intel Corporation 1976 
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ABSOLUTE MAXIMUM RATINGS* 

Ambient Temperature Under Bias 0°C to 70°C 

Storage Temperature -65°C to +150°C 

Voltage On Any Pin With Respect 

to Ground -0.5V to +7V 

Power Dissipation 1.5 Watt 



•COMMENT: 

Stresses above those listed under "Absolute Maximum Ratings" 
may cause permanent damage to the device. This is a stress rating 
only and functional operation of the device at these or any other 
conditions above those indicated in the operational sections of this 
specification is not implied. 



D.C. AND OPERATING CHARACTERISTICS T A = o°c to 70°c, v rr = v DD = +5V ±io%\ v ss = ov 



Symbol 


Parameter 


Limits 


Unit 


Test Conditions 


Min. 


Typ. 


Max. 


V,L 


Input Low Voltage 


-.5 




.8 


V 




V|H 


Input High Voltage 


2.0 




Vcc 


V 






(All Except XTAL1,XTAL2,RESET) 




V|H1 


Input High Voltage (RESET, X1, X2) 


3.8 




V CC 


V 




Vol 


Output Low Voltage 

(BUS, RD, WR, PSEN, ALE) 






.45 


V 


I , = 2.0mA 
OL 


V L1 


Output Low Voltage 

(All Other Outputs Except PROG) 






.45 


V 


I l = 1.6mA 


V OL2 


Output Low Voltage (PROG) 






.45 


V 


Iol = 1.0mA 


V H 


Output High Voltage 
(BUS, RD, WR, PSEN, ALE) 


2.4 






V 


Ioh =-100mA 


V H1 


Output High Voltage 
(All Other Outputs) 


2.4 






V 


Ioh =-50mA 


'lL 


Input Leakage Current 
(T1,lNT) 






±10 


PA 


V SS <V, N <Vcc 


'OL 


Output Leakage Current (BUS, TO) 
(High Impedance State) 






±10 


juA 


V ss +.45<V| N <V C c 


'dd 


Vdq Supply Current 




10 


20 


mA 




>DD + 'CC 


Total Supply Current 




65 


135 


mA 





WAVEFORMS 



•Standard 8748 and 8035 ± 5%, ±10% available. 



Instruction Fetch From External Program Memory 



Read From External Data Memory 



, CY- 



•afc r" t cc~ 



I 



J 



1 



BUS FLOATING ^~l ^ FLOATING ^ ^"^ FLOATING ^ BUS FLOATING )^DDRESS^ X X° ATA X BOATING 



INSTRUCTION 



6^ 



8048/8648/8748/8035 



Write to External Data Memory 



J 



1_ 



bus floatingYaddfsessYfloatingY data Y floating 



A.C. CHARACTERISTICS T A = o°cto 70°c, v cc 


= V DD = +5V±10%», V ss 


= OV 




Symbol 


Parameter 


8048 

8648 (Note 2) 

8748/8035/8035L 


8748-8 
8035-8 


Unit 


Conditions (Note 1) 




Min. 


Max. 


Min. 


Max. 




t-LL 


ALE Pulse Width 


400 




600 




ns 




tAL 


Address Setup to ALE 


150 




150 




ns 




tLA 


Address Hold from ALE 


80 




80 




ns 




*cc 


Control Pulse Width (PSEN, RD, WR) 


700 




1500 




ns 




t-DW 


Data Setup before WR 


500 




640 




ns 




t\ft/D 


Data Hold After WR 


120 




120 




ns 


C L = 20pF 


tCY 


Cycle Time 


2.5 


15.0 


4.17 


15.0 


Ms 


6MHzXTAL 
(3.6MHz XTAL for -8) 


tDR 


Data Hold 





200 





200 


ns 




tRD 


PSEN, RDto Data In 




500 




750 


ns 




t-AW 


Address Setup to WR 


230 




260 




ns 




T-AD 


Address Setup to Data In 




950 




1450 


ns 




*AFC 


Address Float to RD, PSEN 












ns 





Note 1: 



Note 2: 



'Standard 8748 and 8035 ±5%, ± 10% available. 



Control outputs: C|_ = 80 pF 

BUS Outputs: Cl= 150pF, tQY = 2.5jus 

The 8648 is a one-time programmable (at the factory) 8748 which can be ordered as the first 25 pieces of a new 8048 ROM order. 

The substitution of 8648's for 8048's allows for very fast turnaround for initial code verification and evaluation units. The 8648, like 

the 8748, is electrically and functionally interchangeable with the 8048 with the exception of the powerdown mode which the 8648 

does not support and ±5% supply tolerance instead of ±10%. 



A.C. CHARACTERISTICS (PORT 2 TIMING) 

Ta = 0°C to 70° C, Vcc = 5V±10% 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


tCP 


Port Control Setup Before Falling 


110 




ns 






Edge of PROG 




tpc 


Port Control Hold After Falling 
Edge of PROG 


140 




ns 




tPR 


PROG to Time P2 Input Must Be Valid 




810 


ns 




tDP 


Output Data Setup Time 


220 




ns 




tPD 


Output Data Hold Time 


65 




ns 




tPF 


Input Data Hold Time 





150 


ns 




tpp 


PROG Pulse Width 


1510 




ns 




tPL 


Port 2 I/O Data Setup 


400 




ns 




tLP 


Port 2 I/O Data Hold 


150 




ns 





6-5 
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PORT 2 TIMING 



V~A 



EXPANDER 
PORT 



DC 



EXPANDER 
PORT 



DC 



\/ — V 



X 



X 



PORT 2 -3 DATA 



X 



PORT 2q-3 DATA 



X 



PORT CONTROL 



PORT CONTROL 



X 



OUTPUT DATA 



xzzx 



\ 



:c 



/ 



:c 



PROGRAMMING, VERIFYING, AND 
ERASING THE 8748 EPROM 

Programming Verification 

In brief, the programming process consists of: activating 
the program mode, applying an address, latching the 
address, applying data, and applying a programming pulse. 
Each word is programmed completely before moving on to 
the next and is followed by a verification step. The follow- 
ing is a list of the pins used for programming and a descrip- 
tion of their functions: 



Pin 


Function 


XTAL 1 


Clock Input (1 to6MHz) 


Reset 


Initialization and Address Latching 


TestO 


Selection of Program of Verify Mode 


EA 


Activation of Program/Verify Modes 


BUS 


Address and Data Input Data Output 




During Verify 


P20-1 


Address Input 


Vdd 


Programming Power Supply 


PROG 


Program Pulse Input 



WARNING: 

An attempt to program a missocketed 8748 will result in severe 
damage to the part. An indication of a properly socketed part is the 
appearance of the ALE clock output. The lack of this clock may 
be used to disable the programmer. 



Programming/Verification Sequence 

+5V , 



+25V 

' +5V • 



DURING THIS TIME 



- ( ADDRESS A -A 7 X DATA V - 



-( ADDRESS A 8 -A 9 "")- 



+25V 
+5V- 



PROG + 5v- 
+0V 



The Program/Verify sequence is: 

1. Vqq = 5v, Clock applied or internal oscillator operating, 
RESET = Ov, TEST = 5v, EA = 5v, BUS and PROG 
floating. 



2. 
3. 
4. 
5. 
6. 
7. 
8. 
9. 
10. 
11. 
12. 
13. 
14. 
15. 



Insert 8748 in programming socket 

TEST = Ov (select program mode) 

EA = 25v (activate program mode) 

Address applied to BUS and P20-1 

RESET = 5v (latch address) 

Data applied to BUS 

Vqq = 25v (programming power) 

PROG = Ov followed by one 50ms pulse to 25v 



V 



DD 



5v 



TEST = 5v (verify mode) 

Read and verify data on BUS 

TEST = Ov 

RESET = Ov and repeat from step 5 

Programmer should beat conditions of step 1 when 8748 
is removed from socket. 
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AC TIMING SPECIFICATION FOR PROGRAMMING 

T A = 25° C ± 5°C, Vcc = 5V ± 5%, Vdd = 25V ± 1V 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


tAW 


Address Setup Time to RESET t 


4tcy 








tWA 


Address Hold Time After RESET t 


4tcy 








tDW 


Data in Setup Time to PROG t 


4tcy 








tWD 


Data in Hold Time After PROG 1 


4tcy 








tPH 


RESET Hold Time to Verify 


4tcy 








tVDDW 


Vdd 


4tcy 








tVDDH 


Vdd Hold Time After PROG 1 











tPW 


Program Pulse Width 


50 


60 


MS 




tTW 


Test Setup Time for Program Mode 


4tcy 








tWT 


Test Hold Time After Program Mode 


4tcy 








tDO 


Test to Data Out Delay 




4tcy 






tww 


RESET Pulse Width to Latch Address 


4tcy 








tr, tf 


Vdd and PROG Rise and Fall Times 


0.5 


2.0 


MS 




tCY 


CPU Operation Cycle Time 


5.0 




M S 




tRE 


RESET Setup Time Before EA t. 


4tcy 









Note: If Test is high too can be triggered by RESET t. 



DC SPECIFICATION FOR PROGRAMMING 

Ta = 25°C ± 5°C, Vcc = 5V ± 5%, Vdd = 25V ± 1V 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


Vdoh 


Vdd Program Voltage High Level 


24.0 


26.0 


V 




Vddl 


Vdd Voltage Low Level 


4.75 


5.25 


V 




VPH 


PROG Program Voltage High Level 


21.5 


24.5 


V 




VPL 


PROG Voltage Low Level 




0.2 


V 




Veah 


EA Program or Verify Voltage High Level 


21.5 


24.5 


V 




Veal 


EA Voltage Low Level 




5.25 


V 




Idd 


Vdd High Voltage Supply Current 




30.0 


mA 




IPROG 


PROG High Voltage Supply Current 




16.0 


mA 




Iea 


EA High Voltage Supply Current 




1.0 


mA 
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WAVEFORMS FOR PROGRAMMING 

COMBINATION PROGRAM/VERIFY MODE (EPROM'S ONLY) 



\ 



\ / 



/ 



DB0-DB7 



p p LAST 

r2 °~ n ADDRESS 



/ ADDRESS \/ 
~\ (0-7) VALID A 

>CZZ 



DATA TO BE 
PROGRAMMED VALI 



A. 



ADDRESS (8-9) VALID 



7 



\ 



-tVDDH 

I tWT" 



\ 



a r 



>-i 



/ V DATA \ / NEXTADDR \f 

_ ~\ A valid r \ v ^ r ° A 



T~\ 



J- 



■"V 



NEXT 
ADDRESS 



VERIFY MODE (ROM/EPROM) 



DB0-DB7 



\ 



>-< 



X 



/ 



\ 



/ 



\ 



ADDRESS 
(0-7) VALID 



XDATA OUT \_ _ __ _/ 
VALID / A. 



NEXT 
ADDRESS 



ADDRESS (8-9) VALID 



NOTES: 

1. PROG MUST FLOAT IF EA IS LOW (i.e., 4 25V), OR IF TO = 5V FOR THE 8748. 
FOR THE 8048 PROG MUST ALWAYS FLOAT. 

2. V EAH FOR 8048= 11.4V MIN., 12.6V MAX. 

3. THE_FOLLOWING CONDITIONS MUST BE MET: 

CS = TTLT 
A0 = TTL '0' 
THIS CAN BE DONE USING 10K RESISTORS TO V cc , V ss RESPECTIVELY. 

4. X, ANDX 2 DRIVEN BY 3 MHz CLOCK WILL GIVE 5«sec t CY . THIS IS GOOD 
FOR -8 PARTS AS WELL AS NON -8 PARTS. 



X 



X NEXT DATA \ 
OUT VALID f" 



NEXT ADDRESS VALID 



The 8748 EPROM can be programmed by either of two 
Intel products: 

1. PROMPT-48 Microcomputer Design Aid, or 

2. Universal PROM Programmer (UPP-101 or UPP-102) 
peripheral of the Intellec® Development System with a 
UPP-848 Personality Card. 



Note: See Appendix 2 for 8048 ROM ordering procedures. To min- 
imize turnaround time on the first 25 pieces 8648 may be specified 
on the ROM order. 
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NEW HIGH PERFORMANCE 

8049/8039/8039-6 

SINGLE COMPONENT 8-BIT MICROCOMPUTER 

*8049 Mask Programmable ROM 
*8039 External ROM or EPROM 
*New 11 MHz Operation 



8-Bit CPU, ROM, RAM, I/O in 
Single Package 

Single 5V ± 10% Supply 

1.36 iisec Cycle; All Instructions 
1 or 2 Cycles 

Over 90 Instructions: 70% Single Byte 

Pin Compatible with 8048/8748 



d 2Kx8ROM 
128x8 RAM 
27 I/O Lines 

d Interval Timer/Event Counter 

a Easily Expandable Memory and I/O 

d Compatible with MCS Memory and I/O 

□ Single Level Interrupt 



The Intel® 8049/8039/8039-6 is a totally self-sufficient 8-bit parallel computer fabricated on a single silicon chip using 
Intel's N-channel silicon gate MOS process. 

The 8049 contains a 2Kx8 program memory, a 128x8 RAM data memory, 27 I/O lines, and an 8-bit timer/counter in 
addition to on board oscillator and clock circuits. For systems that require extra capability, the 8049 can be expanded 
using standard memories and MCS-80™/MCS-85™ peripherals. The 8039 is the equivalent to an 8049 without program 
memory. The 8039-6 is a lower speed (6MHz) version of the 8039. 

To reduce development problems to a minimum and provide maximum flexibility, two interchangeable pin-compatible 
versions of this single component microcomputer exist: the 8049 with factory-programmed mask ROM program 
memory for low-cost high volume production, and the 8039 without program memory for use with external program 
memories in prototype and preproduction systems. 

This microprocessor is designed to be an efficient controller as well as an arithmetic processor. The 8049 has exten- 
sive bit handling capability as well as facilities for both binary and BCD arithmetic. Efficient use of program memory 
results from an instruction set consisting mostly of single byte instructions and no instructions over two bytes in 
length. 



PIN CONFIGURATION 



TOC 1 

XTAL iC 2 

XTAL ![ 3 

RESETC 4 

SSE 5 

fNtC 6 

EAC 7 

RbC 8 

PSENC 9 

wrC 10 
aleC 11 

DS„C 12 
DB, H 13 
DBjC 14 
DB 3 C 15 
DB 4 C 16 
DB 5 C 17 
DB 6 C 18 
DB 7 C 19 
V, S C 20 



8049 
8039 



moN 




LOGIC SYMBOL 


D v cc 

UP27 


■ XTAL- 






0>T 


I]P26 
3P25 
DP24 


RESE 


r — •- 




<A>T 


HP17 
DP16 


SINGLE 
STEP 




— »READ 


HP15 
I]P14 


EXTERNAL 

MEM. 


8049 




DP13 




r ». 




— ► WRITE 


HP12 


TEST- 








UP11 

Upio 




-— — 




PROGRAM 
— «- STORE 
ENABLE 


Uv DD 


INTERRUPT ► 






Uprog 

3P23 






ADDRESS 
— "-LATCH 
ENABLE 


HP22 
I]P21 
I]P20 


BUS<] 


t> 




PORT 

— ►EXPANDER 

STROBE 



BLOCK DIAGRAM 



2048 WORDS 
PROGRAM 
MEMORY 



7\ 



128 WORDS 

DATA 

MEMORY 



7\ 



\7 



\7 



8BIT 

TIMER/ 

EVENT COUNTER 
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ABSOLUTE MAXIMUM RATINGS* 

AmbientTemperature Under Bias 0°Cto70°C 

Storage Temperature -65°Cto+150°C 

Voltage on Any Pin With 

Respectto Ground -0.5Vto+7V 

Power Dissipation 1.5 Watt 



'COMMENT: Stresses above those listed under "Absolute 
Maximum Ratings" may cause permanent damage to the 
device. This is a stress rating only and functional 
operation of the device at these or any other conditions 
above those indicated in the operational sections of this 
specification is not implied. Exposure to absolute 
maximum rating conditions for extended periods may 
affect device reliability. 



D.C. AND OPERATING CHARACTERISTICS t a = o°cto 70°c, v cc = v DD = +5V±io%, v ss = ov 





Parameter 


Limits 


Unit 


Test Conditions 




Symbol 


Min. 


Typ. 


Max. 




V|L 


Input Low Voltage 


-0.5 




0.8 


V 




V| H 


Input High Voltage 


2.0 




Vcc 


V 








(All Except XTAL1, XTAL2, RESET) 




V|H1 


Input High Voltage (RESET, X1, X2) 


3.8 




Vcc 


V 




Vol 


Output Low Voltage 

(BUS, RD,WR, PSEN,ALE) 






0.45 


V 


I l= 2.0mA 


V OL1 


Output Low Voltage 

(All Other Outputs Except PROG) 






0.45 


V 


l |_ = 1.6mA 


V OL2 


Output Low Voltage (PROG) 






0.45 


V 


Iol = 1-OmA 


V H 


Output High Voltage 
(BUS, RD, WR, PSEN, ALE) 


2.4 






V 


l 0H =- 100MA 


V OH1 


Output High Voltage 
(All Other Outputs) 


2.4 






V 


I OH =-50mA 


IlL 


Input Leakage Current 
(T1,TnT) 






±10 


HA 


Vss^V||\|<Vcc 


lOL 


Output Leakage Current (Bus, TO) 
(High Impedance State) 






±10 


fiA 


Vss+0.45<V| N 


<v cc 


'dd 


Power Down Supply Current 




25 


50 


mA 


T A = 25° C 


■dd+'cc 


Total Supply Current 




100 


170 


mA 


T A = 25° C 



A.C. CHARACTERISTICS t a = o°c to 70°c, v cc = v DD = +5V ±10%, Vss = ov 





Parameter 


8049/8039 
(Note 1) 


8039-6 


Unit 




Symbol 


Min. Max. 


Min. 


Max. 


Conditions (Note 2) 


tLL 


ALE Pulse Width 


150 




400 




ns 




t A L 


Address Setup to ALE 


70 




150 




ns 




t|_A 


Address Hold from ALE 


50 




80 




ns 




tcC 


Control Pulse Width (PSEN, RD, WR) 


300 




700 




ns 




*DW 


Data Set-Up Before WR 


250 




500 




ns 




twD 


Data Hold After WR 


40 




120 




ns 


C L = 20pF 


tcY 


Cycle Time 


1.36 


15.0 


2.5 


15.0 


^s 


11MHZXTAL 
(6MHz XTAL for -6) 


*DR 


Data Hold 





100 





200 


ns 




*RD 


PSEN, RD to Data In 




200 




500 


ns 




*AW 


Address Setup to WR 


200 




230 




ns 




*AD 


Address Setup to Data In 




400 




950 


ns 




Wc 


Address Float to RD, PSEN 


-10 









ns 





Notes: 1. 8039-6 specifications are also valid for 8049/8039 operating at 6MHz. 
2. Control Outputs: C L = 80pF 



BUS Outputs: 



:150pF 
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WAVEFORMS 



INSTRUCTION FETCH FROM EXTERNAL PROGRAM MEMORY 
^ » 



ALE 



PSEN 



l LL" 



BUS FLOATING 



X. 



tec- 



1_ 



ADDRESS 



/ 



V FLOATING \f Nq FLOATING V 



INSTRUCTION 



READ FROM EXTERNAL DATA MEMORY 



ALE 



RD 



J 



L 



FLOATING 



BUS FLOATING NAdDRESsS!^ /\ DATA /\ fl ° at 



ING 



WRITE TO EXTERNAL DATA MEMORY 



ALE 



WR 



1 










1 




■* ^c *■ 
























*l)w 






*wu 
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A.C. CHARACTERISTICS 

T A = 0°C to 70°C, V CC = 5V±10% 





Parameter 


8049/8039 


8039-6 


Unit 




Symbol 


Mln. 


Max. 


Mln. 


Max. 


Conditions (Note 2) 


top 


Port Control Setup Before Falling 
Edge of PROG 


100 




110 




ns 




tpc 


Port Control Hold After Falling Edge 
of PROG 


60 




140 




ns 




tpR 


PROG to Time P2 Input Must Be Valid 




650 




810 


ns 




tpp 


Output Data Setup Time 


200 




220 




ns 




tpD 


Output Data Hold Time 


20 




65 




ns 




tpp 


Input Data Hold Time 





150 





150 


ns 




tpp 


PROG Pulse Width 


700 




1510 




ns 




tpL 


Port 2 I/O Data Setup 


150 




400 




ns 




tLP 


Port 2 I/O Data Hold 


20 




150 




ns 





WAVEFORMS 



PORT 2 TIMING 



^\ 



EXPANDER 
PORT 



DC 



EXPANDER 
PORT 



DC 



y — v 



V PORT 2 .3 DATA V 



>: 



PORT 2o_ 3 DATA 



PORT CONTROL 



PORT CONTROL 



>: 



r~ 



OUTPUT DATA 



;>c=d: 



:c 



:c 



"v. 



/ 
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PIN DESCRIPTION 

Designation Pin # Function 



Vss 
Vdd 

Vcc 

PROG 



20 
26 



40 



25 



P10-P17 


27-34 


Port 1 




P20-P27 


21-24 


Port 2 


35-38 



D0-D7 
BUS 



12-19 



TO 



T1 



INT 



39 



Circuit GND potential 

+5V during operation. Low power 
standby pin. 

Main power supply; +5V during 
operation. 

Output strobe for 8243 I/O 
expander. 

8-bit quasi-bidirectional port. 

8-bit quasi-bidirectional port. 

P20-P23 contain the four high 
order program counter bits during 
an external program memory fetch 
and serve as a 4-bit I/O expander 
bus for 8243 

True bidirectional port which can 
be written or read synchronously 
using the RD, WR strobes. The 
port can also be statically latched. 

Contains the 8 low order program 
counter bits during an external 
program memory fetch, and receives 
the addressed instruction under the 
control of PSEN. Also contains the 
address and data during an external 
RAM data store instructi on, u nder 
control of ALE, RD, and WR. 

Input pin testable using the con- 
ditional transfer instructions JT0 
and JNT0. TO can be designated as 
a clock output using ENT0 CLK 
instruction. 

Input pin testable using the JT1, 
and JNT1 instructions. Can be des- 
ignated the timer/counter input using 
the STRT CNT instruction. 

Interrupt input. Initiates an inter- 
rupt if interrupt is enabled. Inter- 
rupt is disabled after a reset. Also 
testable with conditional jump 
instruction. (Active low) 



Designation Pin # Function 



RD 



RESET 



WR 



ALE 



PSEN 



SS 



EA 



XTAL1 



XTAL2 



8 Output strobe activated during a 
BUS read. Can be used to enable 
data onto the BUS from an external 
device. 

Used as a Read Strobe to External 
Data Memory. (Active low) 

4 Input which is used to initialize the 
processor. Also used during verifi- 
cation, and power down. (Active 
low) (NonTTLV| H ) 

10 Output strobe during a BUS write. 
(Active low) 

Used as write strobe to External 
Data Memory. 

1 1 Address Latch Enable. This signal 
occurs once during each cycle and 
is useful as a clock output. 

The negative edge of ALE strobes 
address into external data and pro- 
gram memory. 

9 Program Store Enable. This output 
occurs only during a fetch to exter- 
nal program memory. (Active low) 

5 Single step input can be used in con- 
junction with ALE to "single step" 
the processor through each in- 
struction. (Active low) 

7 External Access input which forces 

all program memory fetches to re- 
ference external memory. Useful 
for emulation and debug, and 
essential for testing and program 
verification. (Active high) 

2 One side of crystal input for inter- 
nal oscillator. Also input for exter- 
nal source. (Not TTL Compatible) 

3 Other side of crystal input. 
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INSTRUCTION SET 



Mnemonic 



Description 



Bytes Cycle 



Mnemonic 



Description 



Bytes Cycles 





ADDA, R 


Add register to A 1 






ADDA, @R 


Add data memory to A 1 






ADD A, #data 


Add immediate to A 2 


2 




ADDCA, R 


Add register with carry 1 






ADDC A, @R 


Add data memory with carry 1 






ADDCA, #data 


Add immediate with carry 2 


2 




ANLA, R 


And register to A 1 






AN LA, @R 


And data memory to A 1 






ANLA, #data 


And immediate to A 2 


2 




ORLA, R 


Or register to A 1 




o 


ORLA, @R 


Or data memory to A 1 




3 


ORLA, #data 


Or immediate to A 2 


2 


b 

3 


XRLA, R 


Exclusive Or register to A 1 






XRLA, @R 


Exclusive or data memory to A 1 






XRLA, #data 


Exclusive or immediate to A 2 


2 




INC A 


Increment A 1 






DEC A 


Decrement A 1 






CLR A 


Clear A 1 






CPLA 


Complement A 1 






DA A 


Decimal Adjust A 1 






SWAP A 


Swap nibbles of A 1 






RLA 


Rotate A left 1 






RLC A 


Rotate A left through carry 1 






RR A 


Rotate A right 1 






RRCA 


Rotate A right through carry 1 






IN A, P 


Input port to A 1 


2 




OUTLP, A 


Output A to port 1 


2 




AN LP, #data 


And immediate to port 2 


2 


3 


OR LP, #data 


Or immediate to port 2 


2 


3 


INS A, BUS 


Input BUS to A 1 


2 


U 


OUTLBUS, A 


Output A to BUS 1 


2 


3 

a 


ANL BUS,#data 


And immediate to BUS 2 


2 


c 


ORL BUS,#data 


Or immediate to BUS 2 


2 




MOVD A, P 


Input Expander port to A 1 


2 




MOVD P, A 


Output A to Expander port 1 


2 




ANLD P, A 


And A to Expander port 1 


2 




ORLD P, A 


Or A to Expander port 1 


2 


03 


INCR 


Increment register 1 


1 


V, 


INC @R 


Increment data memory 1 


1 


o 
K 


DECR 


Decrement register 1 


1 





JMPaddr 


Jump unconditional 


2 


2 




JMPP@A 


Jump indirect 


1 


2 




DJNZR.addr 


Decrement register and skip 


2 


2 




JCaddr 


Jump on Carry = 1 


2 


2 




JNCaddr 


Jump on Carry = 


2 


2 




J Z addr 


Jump on A Zero 


2 


2 




JNZaddr 


Jump on A not Zero 


2 


2 


u 


JTO addr 


Jump on TO = 1 


2 


2 


? 


JNTOaddr 


Jump on TO = 


2 


2 


00 


JT1 addr 


Jump on T1 = 1 


2 


2 




JNT1 addr 


Jump on T1 = 


2 


2 




JFOaddr 


Jump on FO = 1 


2 


2 




JF1 addr 


Jump on F1 = 1 


2 


2 




JTF addr 


Jump on timer flag 


2 


2 




JNI addr 


Jump on INT= 


2 


2 




JBbaddr 


Jump on Accumulator Bit 


2 


2 



c 


CALL 


Jump to subroutine 2 


2 


3 
O 


RET 


Return 1 


2 


J3 

3 

CO 


RETR 


Return and restore status 1 


2 




CLR C 


Clear Carry 1 






CPL C 


Complement Carry 1 




a) 


CLR F0 


Clear Flag 1 




U. 


CPL F0 


Complement Flag 1 






CLR F1 


Clear Flag 1 1 






CPLF1 


Complement Flag 1 1 






MOV A, R 


Move register to A 1 






MOV A, @R 


Move data memory to A 1 






MOV A, #data 


Move immediate to A 2 






MOV R, A 


Move A to register 1 






MOV@R, A 


Move A to data memory 1 






MOV R, #data 


Move immediate to register 2 


2 


> 


MOV @R, #data Move immediate to data memory 2 


2 


o 


Move A, PSW 


Move PSW to A 1 






MOV PSW, A 


Move A to PSW 1 




D 


XCH A, R 


Exchange A and register 1 






XCHA,@R 


Exchange A and data memory 1 






XCHD A, @R 


Exchange nibble of A and register 1 






MOVX A, @R 


Move external data memory to A 1 


2 




MOVX @R, A 


Move A to external data memory 1 


2 




MOVP A, @A 


Move to A from current page 1 


2 




MOVP3 A, @A 


Move to A from Page 3 1 


2 




MOV A, T 


Read Timer/Counter 1 




0) 


MOVT, A 


Load Timer/Counter 1 




3 


STRTT 


Start Timer 1 




o 


STRT CNT 


Start Counter 1 




£ 


STOP TCNT 


Stop Timer/Counter 1 




ENTCNTI 


Enable Timer/Counter Interrupt 1 




DISTCNTI 


Disable Timer/Counter Interrupt 1 






EN I 


Enable external interrupt 1 






DISI 


Disable external interrupt 1 




o 


SELRB0 


Select register bank 1 




c 


SELRB1 


Select register bank 1 1 




U 


SELMB0 


Select memory bank 1 






SELMB1 


Select memory bank 1 1 






ENT0CLK 


Enable Clock output on TO 1 





NOP 



No Operation 



Mnemonics copyright Intel Corporation 1976, 1977, 1978 




8021 
SINGLE COMPONENT 8-BIT MICROCOMPUTER 



□ 8-Bit CPU, ROM, RAM, I/O in Single 
28- Pin Package 

□ Single 5V Supply ( + 4.5V to 6.5V) 

□ 10 /xsec Cycle; All Instructions 
1 or 2 Cycles 

□ Instructions —8748 Subset 

a High Current Drive Capability— 2 Pins 



a 1K x 8 ROM 
64 x 8 RAM 
21 I/O Lines 

a Interval Timer/Event Counter 

a Clock Generated With Single Resistor 
or Inductor 

□ Zero-Cross Detection Capability 

□ Easily Expandable I/O 



The Intel 8021 is a totally self-sufficient 8-bit parallel computer fabricated on a single silicon chip using Intel's N-channel 
silicon gate MOS process. The features of the 8021 include a subset of the 8048 optimized for low cost, high volume appli- 
cations, plus additional I/O flexibility and power. 

The 8021 contains a 1 K X 8 program memory, a 64 X 8 data memory, 21 I/O lines, and an 8-bit timer/event counter, in addi- 
tion to on-board oscillator and clock circuits. For systems that require extra I/O capability, the 8021 can be expanded using 
the 8243 or discrete logic. 

This microprocessor is designed to be an efficient controller as well as an arithmetic processor. The 8021 has bit handling 
capability as well as facilities for both binary and BCD arithmetic. Efficient use of program memory results from an instruc- 
tion set consisting mostly of single byte instructions and no instructions over two bytes in length. 

To minimize development problems and maximize flexibility, an 8021 system can be easily designed using the 8021 emula- 
tion board, EMB-21. The EMB-21 contains a 40-pin socket which can accommodate either the 8748 shipped with the board 
or an ICE-48 plug. Also, the necessary discrete logic to reproduce the 8021 's additional I/O features is included. 



PIN CONFIGURATION 



P22 C 

P23 C 

PROG C 

POO L" 

P01 C 

P02 C 

P03 C 

P04 C 

P05 C 



P06 
P07 
ALE 



VSS C 14 



3 


vcc 


3 


P21 


D 


P20 


3 


P17 


3 


P16 


3 


P15 


3 


P14 


3 


P13 


3 


P12 


3 


P11 


3 


P10 


3 


RESET 


3 


XTAL2 


3 


XTAL 1 



LOGIC SYMBOL 




ADDRESS 
+- LATCH 
ENABLE 

PORT 

>- EXPANDER 

STROBE 



BLOCK DIAGRAM 



1024WORDS 




64 WORDS 


PROGRAM 




DATA 


MEMORY 




MEMORY 



8-BIT 

TIMER/ 

EVENT COUNTER 



6-15 



8021 



ABSOLUTE MAXIMUM RATINGS* 

Ambient Temperature Under Bias 0°C to 70°C 

Storage Temperature -65°C to +150°C 

Voltage on Any Pin with 

Respect to Ground -0.5V to +7V 

Power Dissipation 1 W 



*COMMENT: Stresses above those listed under ''Absolute Maxi- 
mum Ratings" may cause permanent damage to the device. This Is a 
stress rating only and functional operation of the device at these or 
any other conditions above those indicated in the operational sec- 
tions of this specification is not implied. Exposure to'absotute* 
maximum rating conditions for extended periods may affect cf^yi6e f 
reliability. Vi '- "' 



D.C. AND OPERATING CHARACTERISTICS 

T A = 0°C to 70°C, V CC =5.5V±1V, V ss = 0V 





Parameter 


Limits 


Unit 




Symbol 


Min. 


Typ. 


Max. 


Test Conditions 


V|L 


Input Low Voltage (All except XTAL1, XTAL2) 


-0.5 




0.8 


V 




V| H 


Input High Voltage (All except XTAL1, XTAL2) 


2.0 




V C C 


V 


V CC = 5.0V±10% 


V| H1 


Input High Voltage (All except XTAL1, XTAL2) 


3.0 




Vcc 


V 


V CC = 5.5V ±1V 


Vol 


Output Low Voltage 






0.45 


V 


Iol= 1-6 mA 


V 0L1 


Output Low Voltage (P10, P1 1) 






2.5 


V 


Iol = 1 mA 


Voh 


Output High Voltage (All unless Open Drain) 


2.4 






V 


I O h = 50/xA 


Iol 


Output Leakage Current (Open Drain Option — 
Port 0) 






±10 


/iA 


V ss + 0.45 <V )N < V cc 


'cc 


Vcc Supply Current 






60 


mA 





A.C. CHARACTERISTICS 

T A = 0°C to 70°C, V CC = 5.5V ±1V, V ss = 0V 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


tCY 


Cycle Time 


10.0 


50.0 


/isec 


3MHzXTAL= 10 Msec 


A F 


Oscillator Frequency Variation -Resistor Mode 


-20 


+20 


% 


F = 2.5 MHz 



A.C. TEST CONDITIONS 

Control Outputs: C L = 80 pF 
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PIN DESCRIPTION 



Designation 


Pin# 


Vss 


14 


Vcc 


28 


PROG 


3 


P00-P07 


4-11 


PortO 




P10-P17 


18-25 


Portl 




P20-P23 


26-27 


Port 2 


1-2 



Function 



Designation Pin # Function 



T1 



13 



Circuit GND potential 

+5V power supply 

Output strobe for 8243 I/O Ex- 
pander 

8-bit quasi-bidirectional port 

8-bit quasi-bidirectional port 

4-bit quasi-bidirectional port 
P20-P23 also serve as a 4-bit I/O 
expander bus for 8243 

Input pin testable using the JT1 
and JNT1 instructions. Can be 
designated the timer/event count- 
er input using the STRT CNT 
instruction. Also allows zero- 



RESET 17 



ALE 



12 



XTAL1 15 



XTAL2 16 



crossover sensing of slowly mov- 
ing AC inputs. 

Input used to initialize the proces- 
sor by clearing status flip-flops 
and setting program counters to 
zero. 

Address Latch Enable. Signal oc- 
curing once every 30 input clocks, 
used as an output clock. 

One side of crystal, inductor, or 
resistor input for internal oscilla- 
tor. Also input for external source. 
(Not TTL compatible.) 

Other side of timing control 
element. 



INSTRUCTION SET 



Description 



Bytes Cycle 



Description 



Bytes Cycle 



ADD 


A,R 


Add register to A 






ADD 


A,@R 


Add data memory to A 






ADD 


A,#data 


Add immediate to A 


2 


2 


ADDC 


A,R 


Add with carry 






ADDC 


A,@R 


Add with carry 






ADDC 


A,#data 


Add with carry 


2 


2 


ANL 


A,R 


And- register to A 






ANL 


A,@R 


And data memory to A 






ANL 


A,#data 


And immediate to A 


2 


2 


ORL 


A,R 


Or register to A 






ORL 


A,@R 


Or data memory to A 






ORL 


A,#data 


Or immediate to A 


2 


2 


XRL 


A,R 


Exclusive Or register to A 






XRL 


A,@R 


Exclusive or data memory to A 






XRL 


A,#data 


Exclusive or immediate to A 


2 


2 


INC 


A 


Increment A 






DEC 


A 


Decrement A 






CLR 


A 


Clear A 






CPL 


A 


Complement A 






DA 


A 


Decimal Adjust A 






SWAP 


A 


Swap nibbles of A 






RL 


A 


Rotate A left 






RLC 


A 


Rotate A left through carry 






RR 


A 


Rotate A right 






RRC 


A 


Rotate A right through carry 






IN 


A,P 


Input port to A 




2 


OUTL 


P,A 


Output A to port 




2 


MOVD 


A,P 


Input Expander port to A 




2 


MOVD 


P,A 


Output A to Expander port 




2 


ANLD 


P,A 


And A to Expander port 




2 


ORLD 


P,A 


Or A to Expander port 




2 


INC 


R 


Increment register 




1 


INC 


@R 


Increment data memory 




1 



JMP 


addr 


Jump unconditional 


2 


2 


JMPP 


@A 


Jump indirect 


1 


2 


DJNZ 


R.addr 


Decrement register and Jump 
on R not zero 


2 


2 



JC 


addr 


JNC 


addr 


JZ 


addr 


JNZ 


addr 


JT1 


addr 


JNT1 


addr 


JTF 


addr 



CALL 
RET 



Jump on Carry = 1 
Jump on Carry = 
Jump on A Zero 
Jump on A not Zero 
Jump on T1 = 1 
Jump on T1 = 
Jump on timer flag 



Jump to subroutine 
Return 



No Operation 



CLR 


C 


Clear Carry 1 




CPL 


C 


Complement Carry 1 




MOV 


A,R 


Move register to A 1 




MOV 


A,@R 


Move data memory to A 1 




MOV 


A,#data 


Move immediate to A 2 


2 


MOV 


R,A 


Move A to register 1 




MOV 


@R,A 


Move A to data memory 1 




MOV 


R,#data 


Move immediate to register 2 


2 


MOV 


@R,#data 


Move immediate to data memory 2 


2 


XCH 


A,R 


Exchange A and register 1 




XCH 


A,@R 


Exchange A and data memory 1 




XCHD 


A,@R 


Exchange nibble of A and register 1 




MOVP 


A,@A 


Move to A from current page 1 


2 


MOV 


A,T 


Read Timer/Counter 1 




MOV 


T,A 


Load Timer/Counter 1 




STRT 


T 


Start Timer 1 




STRT 


CNT 


Start Counter 1 




STOP 


TCNT 


Stop Timer/Counter 1 





8021 



FUNCTIONAL SPECIFICATIONS 

The following is a functional description of the major ele- 
ments of the 8021. 

Program Memory 

The 8021 contains 1KX 8 of mask programmable ROM. 
No external ROM expansion capability is provided. 

Data Memory 

A 64 X 8 dynamic RAM is located on chip for data storage. 
All locations are indirectly addressable and eight designated 
locations are directly addressable. Also, included in the 
memory is the address stack, addressed by a 3-bit stack 
pointer. 

Memory is organized as shown in Figure 1. The least signi- 
ficant 8 addresses, 0—7, are directly addressable by any of 
the 11 direct register instructions. The locations are readily 
accessible for a variety of operations with the least number 
of instruction bytes required for their manipulation. 

Registers and 1 have yet another function, in that they 
can be used to indirectly address all locations in memory, 
using the indirect register instructions. These indirect RAM 
address registers, IRAR's, are especially useful for repeti- 
tive-type operations on adjacent memory locations. The 
indirect register instruction specifies which IRAR to use, 
and the contents of the IRAR is used to address a location 
in RAM. The contents of the addressed location is used 
during the execution of the instruction, and may be modi- 
fied. A value larger than 63 should not be preset in the 
IRAR when selected by an indirect register instruction. 
IRAR's may point to addresses 0—7, if desired. 

Locations 8—23 may be used as the address stack. The 
address stack enables the processor to keep track of the 
return addresses generated from CALL instructions. A 3-bit 
stack pointer (SP) supplies the address of the locations to 
be loaded with the next return address generated. The SP to 
this pushdown stack is incremented by one after a return 
address is stored, and decremented by one before an 
address is fetched during a RET. A total of 8 levels of 
nesting is possible. The SP is initialized to location 8 upon 
RESET. Since each address is 10 bits long, two bytes must 
be used to store a single address. The SP is incremented 
and decremented by one, but each increment or decrement 
moves the address pointed to by two. Therefore, only even 
numbered addresses are pointed to. 

If a particular application does not require 8 levels of nest- 
ing, the unused portion of the stack may be used as any 
other indirectly addressable scratchpad location. For 
example, if only 3 levels of subroutine nesting are used, 
then only locations 8—15 need be reserved for the address 
stack, and locations 16—63 can be used for data storage. 
The actual program counter address is not stored in the 
address stack. A separate register retains its value. 



Figure 1. Internal RAM Organization 

Oscillator and Clock 

The 8021 contains its own onboard oscillator and clock 
circuit, requiring only an external timing control element. 
This control element can be a crystal, inductor, resistor, or 
clock in. The capacitor normally required in resistor or 
inductor timing control operation is integrated onto the 
8021. All internal time slots are derived from the external 
element, and all outputs are a function of the oscillator 
frequency. Pins X1 and X2 are used to input the particular 
control element. An instruction cycle consists of 10 states, 
and each state is a time slot of 3 oscillator periods. There- 
fore, to obtain a 10 Msec instruction cycle, a 3 MHz crystal 
should be used. 

Timer/Event Counter 

An interval timer is available to enable the user to keep 
track of time elapsed or number of events occurred, during 
normal program execution and flow. 

By a MOV T,A instruction, the contents of the accumulator 
are loaded to the timer. At the STRT T command an inter- 
nal prescaler is zeroed and thereafter increments once each 
30 input clocks (once each single cycle instruction, twice 
each double cycle instruction). The prescaler is a divide by 
32. At the (11111) to (00000) transition the timer is incre- 
mented. The timer is 8 bits and an overflow (FFH) to 
(00H) timer flag is set. A conditional branch is available for 
testing this flag, the flag being reset each test. Total count 
capacity for the timer is 2 8 X 2 5 = 8192 or 81.9 msec at a 
10 /isec cycle time. Contents of the timer are moved to the 
accumulator by the MOV A,T instruction without disturb- 
ing the counting process. 

The timer may also be used as an event counter. After a 
STRT CNT command, the chip will respond to a high to 
low transition on the Test 1 pin by incrementing the timer. 
Transitions can occur no faster than one each three instruc- 
tion cycles. 

The timer and event functions are exclusive. Counting or 
timing may be started or stopped (STOP TCNT) at will. 
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Input/Output Capabilities 

The 8021 I/O configurations are highly flexible. A number 
of different configurations are possible, tailoring an 8021 to 
a given task. Other than the power supply and dedicated 
pins, all other pins (20) can be used for input, output, or 
both, depending on the configuration. 

P20-P23 and P10-P17 are quasi-bidirectional, and Test 1 
is directly testable through program control. A simplified 
schematic of the quasi-bidirectional interface is shown in 
Figure 2. This configuration allows buffered outputs, and 
also allows external input. When writing a "0" or low value 
to these ports, the large pulldown device sinks an external 
TTL load. When writing a "1", a large current is supplied 
through the large pullup device to allow a fast data transfer. 
After a short time (less than one instruction cycle), the 
large device is shut off and the small pullup maintains the 
"1" level indefinitely. However, in this situtation, an input 
device capable of overriding the small amount of sustaining 
current supplied by the pullup device can be read. (Alterna- 
tively, the data written can be read). So, by writing a "1" 
to any particular pin, that pin can serve either as a true 
high-level latched output pin, or as just a pullup resistor on 
an input. This allows maximum user flexibility in selecting 
his input or latched output pins, with a minimum of 
external components. 

Port 00—07 is also quasi-bidirectional, except there is no 
large pullup device. As outputs, this port is essentially 
open drain. 

By mask option the small pullup devices on POO— P07 may 
be deleted on any pin providing a true open drain output. 
This is useful in driving analog circuits and certain loads, 
such as keyboards. 

Also available is the 8243 I/O expander chip, which pro- 
vides additional I/O capability with a limited number of 
overhead pins. This chip has 4 directly addressable 4-bit 
ports. It connects to the PROG pin, which provides a clock, 
and pins P20— P23, which provide address and data. These 
ports can be written with a MOVD P,A; ANLD P,A; and 
ORLD P,A for Ports 4—7. A high to low transition on 
PROG signifies that address and control are available on 
P20-P23. The previous data on P20-P23 before an output 
expander instruction is lost. Therefore, when using an 
output expander P20— P23 are not useful for general 
input/output. Reading is via the MOVD A,P. This circuit 
configuration is shown in Figure 3. 

The Test 1 pin has a special bias input that allows zero- 
crossover sensing of slowly moving inputs. This is especially 
useful in SCR control of 60 Hz power and in developing 
time of day routines. As a ROM mask option there is a 
pullup resistor that is useful for switch contact input or 
standard TTL. See Figure 4. 




INPUT BUFFER 



Figure 2. Quasi-Bidirectional Port Structure 



P20-3 
PROG 



N V 



A- 



P20-3 
PROG 



Figure 3. I/O Expander Interface 



(a) ZERO CROSS DETECT 



>— >- 



->J 



(b) OPTIONAL PULLUP RESISTOR 



MUCH LOWER RESISTANCE 




Figure 4. Test 1 Pin 
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CPU 

The 8021 CPU has arithmetic and logical capability. A wide 
variety of arithmetic and logic instructions may be exer- 
cised, which affect the contents of the accumulator, and/or 
direct or indirect scratchpad locations. Provisions have been 
made for simplified BCD arithmetic capability through the 
use of the DAA, SWAP A, and XCHD instructions. In 
addition, MOVP A,@A allows table lookup for display 
formating and constants. Jump conditions such as zero, 
not zero refer to the accumulator contents at the time of 
the condition. 

Reset 

The 8021 may see poorly regulated and noisy power sup- 
plies. A useful feature is to sense when the power supply 
dips and do a reset to prevent continued operation with 
incorrect data. This feature may be implemented on the 
8021 by connecting a diode between the RESET node and 
ground. See Figure 5. 

A reset will then be forced if the supply drops approxi- 
mately 1.5 volts and rapidly recovers. One instruction 
cycle will reset the 8021 to the initialized state. 

By removing the diode and using only the capacitor, voltage 
drops in Vcc will not cause a RESET. 




FIGURE 5. POWER ON RESET 



Differences Between the 8021 and the 8748 

Although the 8021 is basically an electrical and functional 
subset of the 8748, there are some differences: 



1. Pin Out - As the 8021 is a 28-pin DIP, some form 
of adapter must be used to interface the 8021 
socket to ICE-48. An emulation board, EMB-21, has 
been designed to perform this function. The 
EMB-21 also accounts for the increased flexibility 
of some 8021 I/O lines. 

2. Instruction Time — The 8021 instruction cycle is 30 
clock cycles long, the 8748 instruction cycle is 15 
clocks long. Where exact timing is important the 
8748 breadboard part should be operated at half the 
8021 clock rate. 

3. Test 1 — To facilitate developing time of day rou- 
tines from 60 Hz, and for SCR control, the Test 1 
pin without the pullup resistor option will detect 
zero crossing of a capacitively coupled AC input. 

4. Quasi-Bidirectional Ports — All 8021 ports are quasi- 
bidirectional to facilitate stand-alone use. Port has 
open drain outputs and by mask option it may or 
may not have pullup resistors. 

5. Oscillator — The 8021 has on-chip oscillator that is 
optimized for the single resistor mode. External 
connection will differ from the 8748. 

6. Dynamic RAM and Logic — The 8021 utilizes 
dynamic RAM and some dynamic logic. Input 
clocking must be maintained above the minimum 
rate or improper operation may result. 

7. High Current Outputs — Very high current drive is 
desirable for minimizing external parts required to 
do high power control. P10 and P11 have been 
designated high drive outputs capable of sinking 
7 mA at Vss +2.5 volts. (For clarity, this is 7 'mA to 
Vss with a 2.5 volt drop across the buffer.) These 
pins may, of course, be paralleled for 14 mA drive if 
the output logic states are always the same. 

8. Reset — Reset has been modified on the 8021, as 
previously noted. A reset will be forced if the power 
supply drops approximately 1.5 volts and rapidly 
recovers, if a diode is used in the reset circuit. This 
prevents continued operation with incorrect data 
caused by a poorly regulated and/or noisy power 
supply. 

9. Instruction Set — The following instructions, which 
are found in the 8748, have been deleted from the 
8021 instruction set. 



Data Moves 


Registers 


Branch 


Timer 


Control 


Input/Output 


MOV A.PSW 
MOV PSW.A 
MOVX A,@R 


DEC R 


JT0 addr 
JNT0 addr 
JF0 addr 
JF1 addr 
JNI addr 
JBb addr 


EN TCNTI 
DIS TCNTI 


EN I 
DIS I 
SEL RBO 
SEL RB1 
SEL MBO 
SEL MB1 
ENT0 CLK 


ANL P,#data 
ORL P,#data 
INS A.BUS* 


Flags 


Subroutine 




CLR F0 
CPL F0 
CLR F1 
CPL F1 




MOVP3 A,@A 


RETR 


ANL BUS,#data 
ORL BUS,#data 



*These Instructions have been replaced in the 8021 by 
IN A,PO and OUTL PO,A respectively. 
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8022 

SINGLE COMPONENT 8-BIT MICROCOMPUTER 
WITH ON-CHIP A/D CONVERTER 



□ 8-Bit CPU, ROM, RAM, I/O in Single 
40-Pin Package 

□ On-Chip 8-Bit A/D Converter; Two Input 
Channels 

□ 8 Comparator inputs (Port 0) 

□ Zero-Cross Detection Capability 
d Single 5V Supply (4.5V to 6.5V) 

□ High Current Drive Capability — 2 Pins 

□ Two Interrupts — External and Timer 

The Intel® 8022 is the newest member of the MCS-48™ family of single chip 8-bit microcomputers. It is designed to 
satisfy the requirements of low cost, high volume applications which involve analog signals, capacitive touchpanel 
keyboards, and/or large ROM space. The 8022 addresses these applications by integrating many new functions on- 
chip, such as A/D conversion, comparator inputs and zero-cross detection. 

The features of the 8022 include 2K bytes of program memory (ROM), 64 bytes of data memory (RAM), 28 I/O lines, an 
on-chip 8-bit A/D converter with two input channels, an 8-bit port with comparator inputs for interfacing to low voltage 
capacitive touchpanels or other non-TTL interfaces, external and timer interrupts, and zero-cross detection capability. 
In addition, it contains the 8-bit interval timer/event counter, on-board oscillator and clock circuitry, single 5V power 
supply requirement, and easily expandable I/O structure common to all members of the MCS-48 family. 

The 8022 is designed to be an efficient controller as well as an arithmetic processor. It has bit handling capability plus 
facilities for both binary and BCD arithmetic. Efficient use of program memory results from using the MCS-48 instruc- 
tion set which consists mostly of single byte instructions and has extensive conditional jump and direct table lookup 
capability. Program memory usage is further reduced via the 8022's hardware implementation of the A/D converter 
which simplifies interfacing to analog signals. 



□ 2K x 8 ROM, 64 x 8 RAM, 28 I/O Lines 

d 10 fisec Cycle; All Instructions 1 or 2 
Cycles 

□ Instructions — 8048 Subset 

□ Interval Timer/Event Counter 

d Clock Generated with Single Resistor, 
Inductor, or Crystal 

d Easily Expandable I/O 



PIN CONFIGURATION 



LOGIC SYMBOL 

Vcc Vss 



BLOCK DIAGRAM 



P26 C 


1 


40 


1 v cc 


P27 C 


2 


39 


3 P25 


AV C c C 


3 


38 


3 P24 


Varef C 


4 


37 


3 PROG 


AN1 C 


5 


36 


3 P23 


AN0 C 


6 


35 


3 P22 


AVss C 




34 


3 P21 


T0C 


8 


33 


3 P20 


VthC 


9 


32 


3 P17 


poo C 


10 8022 31 


3 P16 


poi L 


11 


30 


3 P15 


P02 C 


12 


29 


3 P14 


P03 C 


13 


28 


3 P13 


P04 C 


14 


27 


J P12 


posC 


15 


26 


3 P11 


P06 C 


16 


25 


3 Pio 


P07C 


17 


24 


3 RESET 


ALE C 


18 


23 


3 XTAL2 


T1C 


19 


22 


3 XTAL1 


VssC 


20 


21 


J SUBST 



A/D 
REFERENCE"" 



<£>• 



PORTO 
-THRESHOLD 
REFERENCE 




ADDRESS 
- LATCH 
ENABLE 



PORT 
-EXPANDER 
STROBE 



2048 WORDS 
PROGRAM 
MEMORY 



7\ 



64 WORDS 

DATA 
MEMORY 



7T 



A2-. 



1Z 



8- BIT 

TIMER/EVENT 

COUNTER 



7 

TWO CHANNEL 

8-BIT A/D 

CONVERTER 



A/D 
Vcc 



A/D SUBSTRATE 
Vss 
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PIN DESCRIPTION 

Designation Pin # Function 



Designation Pin # Function 



V S s 


20 


Vcc 


40 


PROG 


37 


P00-P07 


10-1 


PortO 





Circuit GND potential. 

+ 5V circuit power supply. 

Output strobe for Intel® 8243 I/O 
expander. 

8-bit open-drain port with com- 
parator inputs. The switching 
threshold is set externally by V TH . 
Optional pull-up resistors may be 
added via ROM mask selection. 

9 Port threshold reference pin. 

25-32 8-bit quasi-bidirectional port. 

33-36 8-bit quasi-bidirectional port. 

38-39 P20-23 also serve as a 4-bit I/O 
1-2 expander for Intel® 8243. 

8 Interrupt input and input pin test- 
able using the conditional trans- 
fer instructions JTO and JNTO. In- 
itiates an interrupt following a 
low level input if interrupt is en- 
abled. Interrupt is disabled after 
a reset. 

19 Input pin testable using the JT1 
and JNT1 conditional transfer in- 
structions. Can be designated 
the timer/event counter input 
using the STRT CNT instruction. 
Also serves as the zero-cross 
detection input to allow zero- 
crossover sensing of slowly mov- 
ing AC inputs. Optional pull-up 
resistor may be added via ROM 
mask selection. 



V T h 

P10-P17 
Port 1 

P20-P27 
Port 2 

TO 



T1 



RESET 24 Input used to initialize the proc- 

essor by clearing status flip-flops 
and setting the program counter 
to zero. 

AV SS 7 A/D converter GND Potential. 

Also establishes the lower limit 
of the conversion range. 

AV CC 3 A/D +5V power supply. 

SUBST 21 Substrate pin used with a bypass 

capacitor to stabilize the sub- 
strate voltage and improve A/D 
accuracy. 

V AREF 4 A/D converter reference voltage. 

Establishes the upper limit of the 
conversion range. 

ANO, AN1 6,5 Analog inputs to A/D converter. 

Software selectable on-chip via 
SEL ANO and SEL AN1 instruc- 
tions. 

ALE 18 Address Latch Enable. Signal oc- 

curring once every 30 input 
clocks (once every single cycle 
instruction), used as an output 
clock. 

XTAL 1 22 One side of crystal, inductor, or 

resistor input for internal oscil- 
lator. Also input for external fre- 
quency source. (Not TTL com- 
patible.) 

XTAL 2 23 Other side of timing control ele- 

ment. This pin is not connected 
when an external frequency 
source is used. 
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ABSOLUTE MAXIMUM RATINGS* 

Ambient Temperature Under Bias 0°C to 70°C 

Storage Temperature -65 °C to + 180°C 

Voltage on Any Pin with 

Respect to Ground -0.5V to + 7V 

Power Dissipation 1 Watt 



'COMMENT: Stresses above those listed under "Absolute Maximum 
Ratings" may cause permenent damage to the device. This is a stress 
rating only and functional operation of the device at these or any other 
conditions above those indicated in the operational sections of this 
specification is not implied. Exposure to absolute maximum rating con- 
ditions for extended periods may affect device reliability. 



D.C. AND OPERATING CHARACTERISTICS 



T A = 0°Cto70°C, V CC = 5.5V ±1V, V £ 



:0V 



Symbol 


Parameter 




Limits 




Unit 


Test Conditions 


Min. 


Typ. 


Max. 


V|L 


Input Low Voltage (All except XTAL 1, 
XTAL 2, Port 0) 


-0.5 




0.8 


V 




V|L1 


Input Low Voltage (Port 0) 


-0.5 




Vth -0.1 


V 




V|H 


Input High Voltage (All except XTAL 1, 
XTAL 2, RESET, Port 0) 


2.0 




Vcc 


V 


V CC = 5.0V ±10% 


V,H1 


Input High Voltage (All except XTAL 1, 
XTAL 2, RESET, Port 0) 


2.4 




Vcc 


V 


V CC = 6.0V ±0.5V 


V|H2 


Input High Voltage (Port 0) 


Vth + 0.1 




Vcc 


V 




V|H3 


Input High Voltage (RESET, XTAL 1) 


3.0 




Vcc 


V 




Vth 


Port Threshold Reference Voltage 







V CC /2 


V 




Vol 


Output Low Voltage 






0.45 


V 


l| L =1.6 mA 


Vou 


Output Low Voltage (P10, P11) 






2.5 


V 


| 0L =7 mA 


Vqh 


Output High Voltage (All unless Open Drain 
Option— Port 0) 


2.4 






V 


l OH = 50)uA 


"li 


Input Leakage Current (T1) 






±10 


MA 


V|N = Vcc 


"lo 


Output Leakage Current (Open Drain 
Option— Port 0) 






±10 


ma 


Vcc^V lN ^V S s+ 0.45V 


•cc 


V cc Supply Current 






80 


mA 




V T 1 


Zero-Cross Detection Input (T1) 


1 




3 


VACpp 


Input through a 
capacitor 



A.C. CHARACTERISTICS 

T A = 0°Cto70°C, V CC = 5.5V ±1V, V ss = 0V 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


*CY 


Cycle Time 


10.0 


50.0 


MS 


3 MHz XTAL = 10 ^s 


t L L 


ALE Pulse Width 


4.6 




MS 


t CY =10^s 


A F 


Oscillator Frequency Variation— Resistor Mode 


-20 


+ 20 


% 


F = 2.5 MHz, R=15kS 


Fti 


Zero-Cross Detection Input Frequency (T1) 


0.03 


1 


kHz 





A.C. TEST CONDITIONS 

Control Outputs: C L =80pF 
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A.C. CHARACTERISTICS 

T A = 0°Cto70°C, V CC =5.5V ±1V, V ss = 0V 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Notes 


tcp 


Port Control Setup Before Falling Edge of PROG 


110 




ns 




tpc 


Port Control Hold After Falling Edge of PROG 


140 




ns 




Expander PR 


PROG to Time P2 Input Must Be Valid 




810 


ns 




Operation top 


Output Data Setup Time 


220 




ns 




tpo 


Output Data Hold Time 


65 




ns 




tp F 


Input Data Hold Time 





150 


ns 




tpp 


PROG Pulse Width 


1510 




ns 




tpRL 


ALE to Time P2 Input Must Be Valid 


810 




ns 




Normal t[>PL 


Output Data Setup Time 


400 




ns 




Operation t PDL 


Output Data Hold Time 


150 




ns 




tPFL 


Input Data Hold Time 


110 




ns 





PORT 2 TIMING 



EXPANDER 

PORT 

OUTPUT 



EXPANDER 
PORT 
INPUT 



DC 



DC 



X 



PORT 2 -3 DATA 



X 



y PORT 2 -3 DATA Y 



PORT CONTROL 



PORT CONTROL 



X 



OUTPUT DATA 



:xzzk 



INPUT 
DATA 



:c 



xz 



7 
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A/D CONVERTER CHARACTERISTICS 

T A = 0°Cto70°C, V CC = 5.5V ±1V, V ss = 0V, AV CC = 5.5V ±1V, AV ss = 0V 



Parameter 


Min. 


Typ. 


Max. 


Unit 


Comments 


Resolution 


8 






Bits 




Non-Linearity 




±V2 




LSB 


(Note 1) 


Zero Error 









LSB 


(Note 2) T A =25°C 


Full Scale Error 









LSB 


(Note 3) T A =25°C 


Quantization Error 




± 1 /2 




LSB 


(Note 4) 


Absolute Accuracy 




±1 




% 


(Note 5) 


Conversion Range 


AV SS 




V AREF 


V 




v aref 


AV cc /2 




AVcc 


V 




Input Capacitance (ANO, AN1) 




1 




PF 




Conversion Time 


4 




4 


*CY 




Sample Hold Time (t AS ) 




0.07 




*CY 


(Note 6) 


Sample Hold Time (t AH ) 




0.23 




tcY 


(Note 6) 


Sample Setup Before Falling Edge of ALE (t ss ) 




0.20 




tcY 




Sample Hold After Falling Edge of ALE (t S H) 




0.10 




ICY 





ANALOG INPUT TIMING 



ALE 



ANALOG 
INPUT 



tAS" 



\ 



-tss- 



>! 



X 



-tAH" 



NOTES: 

1. Non-linearity error is the maximum deviation from a straight line through the end points of the A/D transfer characteristics. 

2. Zero error is the difference between the output of an ideal and the actual A/D for zero input voltage. 

3. Full-scale error is the difference between the output of an ideal and the actual A/D for full-scale input voltage. 

4. Quantization error is the uncertainty caused by the converters finite resolution. 

5. Absolute accuracy describes the difference between the actual input voltage and the full-scale weighted equivalent of the binary output. Included 
are quantizing and all other errors. 

6. The analog input must be maintained at a constant voltage during the sampling time (t A g) and the sample hold time (t A n). 
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INSTRUCTION SET 



Description 



Description 



Hexadecimal 
Bytes Cycle Opcode 



Hexadecimal 
Bytes Cycle Opcode 



ADD A,R r 


Add register to A 1 


1 


68-6F 


ADD A,@R 


Add data memory to A 1 


1 


60-61 


ADD A,#data 


Add immediate to A 2 


2 


03 


ADDC A,R r 


Add register with carry 1 


1 


78-7 F 


ADDC A,@R 


Add data memory with 1 
carry 


1 


70-71 


ADDC A,#data 


Add immediate with 2 
carry 


2 


13 


ANL A,R r 


And register to A 1 


1 


58-5F 


ANL A,@R 


And data memory to A 1 


1 


50-51 


ANL A,#data 


And immediate to A 2 


2 


53 


ORL A,R r 


Or register to A 1 


1 


48-4 F 


ORL A,@R 


Or data memory to A 1 


1 


40-41 


5 ORLA,#data 


Or immediate to A 2 


2 


43 


n XRLA,R r 


Exclusive Or register 1 


1 


D8-DF 


3 


to A 






= XRLA,@R 


Exclusive Or data 1 


1 


D0-D1 


u 


memory to A 






XRL A,#data 


Exclusive Or immediate 2 
to A 


2 


D3 


INC A 


Increment A 1 


1 


17 


DEC A 


Decrement A 1 


1 


07 


CLR A 


Clear A 1 


1 


27 


CPLA 


Complement A 1 


1 


37 


DA A 


Decimal adjust A 1 


1 


57 


SWAP A 


Swap nibbles of A 1 


1 


47 


RLA 


Rotate A left 1 


1 


E7 


RLC A 


Rotate A left through 1 
carry 


1 


F7 


RRA 


Rotate A right 1 


1 


77 


RRC A 


Rotate A right through 1 
carry 


1 


67 


IN A, P p 


Input port to A 1 


2 


08,09,0A 


OUT P p A 


Output A to port 1 


2 


90,39,3A 


a MOVD A,P p 


Input expander port 1 


2 


0C-0F 




to A 






§ MOVD P p ,A 


Output A to expander 1 


2 


3C-3F 


a 


port 






£ ANLD P p ,A 


And A to expander port 1 


2 


9C-9F 


ORLD P p ,A 


Or A to expander port 1 


2 


8C-8F 


» INC R r 


Increment register 1 


1 


18-1 F 


•2 INC@R 


Increment data memory 1 


1 


10-11 





JMPaddr 


Jump unconditional 


2 


2 


04,24,33,64, 
84,A4,C4,E4 




JMPP @A 


Jump indirect 


1 


2 


B3 


u 


DJNZR.addr 


Decrement register and 


2 


2 


E8-EF 


OS 




jump on R not zero 








00 


JC addr 


Jump on carry = 1 


2 


2 


F6 




JNCaddr 


Jump on carry = 


2 


2 


E6 




JZ addr 


Jump on A zero 


2 


2 


C6 




JNZaddr 


Jump on A not zero 


2 


2 


96 



JT0 


JumponT0=1 2 


2 


36 


JNT0 


JumponT0 = 2 


2 


26 


JT1 addr 


Jump on T1 = 1 2 


2 


56 


JNT1 addr 


Jump on T1 = 2 


2 


46 


JTF addr 


Jump on timer flag 2 


2 


16 


0) 

~ CALL 


Jump to subroutine 1 


2 


14,34,54,74, 


o 






94,B4,D4,F4 


■§ RET 

CO 


Return 1 


2 


83 


| CLRC 


Clear carry 1 


1k 


97 


C CPLC 


Complement carry 1 


1 


A7 


MOV A,R r 


Move register to A 1 


1 


F8-FF 


MOV A,@R 


Move data memory to A 1 


1 


F0-F1 


MOV A,#data 


Move immediate to A 2 


2 


23 


MOV R r ,A 


Move A to register 1 


1 


A8-AF 


MOV @R,A 


Move A to data memory 1 


1 


A0-A1 


MOV R r ,#data 


Move immediate to 2 


2 


B8-BF 




register 






o MOV@R,#data Move immediate to 2 


2 


B0-B1 


2 


data memory 






■5 XCHA,R r 


Exchange A and 1 


1 


28-2 F 


a 


register 






XCH A,@R 


Exchange A and data 1 
memory 


1 


20-21 


XCHD A,@R 


Exchange nibble of A 1 
and register 


1 


30-'31 


MOVP A,@A 


Move to A from current 1 
page 


2 


A3 


| MOVA.T 


Read timer/counter 1 


1 


42 


= MOVT.A 


Load timer/counter 1 


1 


62 


&> STRTT 


Start timer 1 


1 


55 


| STRTCNT 
p STOPTCNT 


Start counter 1 


1 


45 


Stop timer/counter 1 


1 


65 


| RAD 


Move conversion result 1 


2 


80 


> 


register to A 






o SELAN0 
o 


Select analog input 1 


1 


85 


zero 






| SELAN1 


Select analog input one 1 


1 


95 


EN I 


Enable external 1 
interrupt 


1 


05 


& DISI 


Disable external 1 


1 


15 


a 


interrupt 






2 EN TCNTI 


Enable timer/counter 1 


1 


25 


- 


interrupt 






DIS TCNTI 


Disable timer/counter 1 
interrupt 


1 


35 


RET I 


Return from interrupt 1 


2 


93 


NOP 


No operation 1 


1 


00 



SYMBOLS AND ABBREVIATIONS USED 



A Accumulator 

addr 11-Bit Program Memory Address 

AN0, AN1 Analog Input 0, Analog Input 1 

CNT Event Counter 

data 8-Bit Number or Expression 

I Interrupt 



P Mnemonic for "in-page" Operation 

Pp Port Designator (P = 1 , 2 or 4-7) 

Rr Register Designator (r = 0-7) 

T Timer 

TO, T1 Test 0, Test 1 

# Immediate Data Prefix 

@ Indirect Address Prefix 



6-26 



8022 



FUNCTIONAL DESCRIPTION 

PROGRAM MEMORY 

The 8022 program memory consists of 2048 words 8 bits 
wide which are addressed by the program counter. The 
memory is ROM which is mask programmable at the fac- 
tory. No external ROM expansion capability is provided. 
There are three locations in program memory of special 
importance. 

Location 0: Activating the RESET line of the proces- 
sor causes the first instruction to be 
fetched from location 0. 

Location 3: Activating the interrupt input line of the 
processor (if interrupt is enabled) causes 
a jump to subroutine. 

Location 7: A timer/event counter interrupt resulting 
from a timer/counter overflow causes a 
jump to subroutine (if timer/counter inter- 
rupt is enabled). 

Therefore, the first instruction to be executed after in- 
itialization is stored in location 0, the first word of an ex- 
ternal interrupt service routine is stored in location 3, 
and the first word of a timer/event counter interrupt ser- 
vice routine is stored in location 7. 



7|6|5|4|3|2|1|0 



LOCATION 3— EXTERNAL INTERRUPT 

VECTORS PROGRAM HERE 



RESET VECTORS PROGRAM HERE 



PROGRAM MEMORY MAP 



Program memory can be used to store constants as well 
as program instructions. The MOVP instruction allows 
easy table lookup for constants and display formatting. 



DATA MEMORY 

On-chip data memory is organized as 64 words eight bits 
wide. All locations are indirectly addressable and eight 
designated locations are directly addressable. Also in- 
cluded in the data memory is the program counter stack, 
addressed by a 3-bit stack pointer. 

The first eight locations (0-7) of the array are designated 
as working registers and are directly addressable by any 
of the 11 direct register instructions. These locations 
are readily accessible for a variety of operations with a 
minimum number of instruction bytes required for their 
manipulation. Thus, they are usually used to store fre- 
quently accessed intermediate results. The DJNZ in- 



struction makes very efficient use of the working regis- 
ters as program loop counters by allowing the program- 
mer to decrement and test the register in a single in- 
struction. 

Registers and 1 have yet another function in that they 
can be used to indirectly address all locations in the 
data memory using the indirect register instructions. 
These two RAM pointer registers are especially useful 
for repetitive type operations on adjacent memory loca- 
tions. The indirect register instruction specifies which 
pointer register to use and the content of the pointer 
register is used to address a location in RAM. The con- 
tents of the addressed location are used during the exe- 
cution of the instruction and may be modified. The 
pointer registers may also point to registers 0-7, if 
desired. 

Locations 8-23 serve a dual role in that they contain the 
8-level program counter stack, two RAM locations per 
level. The program counter stack enables the processor 
to keep track of the return addresses generated by inter- 
rupts or CALL instructions by storing the contents of 
the program counter prior to servicing the subroutine. A 
3-bit stack pointer determines which of the program 
counter stack's eight register pairs will be loaded with 
the next return address generated. The stack pointer, 
when initialized to 000 by RESET, points to RAM loca- 
tions 8 and 9. The first subroutine jump or interrupt 
results in the program counter contents being trans- 
ferred to locations 8 and 9. The stack pointer is then in- 
cremented by one and points to locations 10 and 11 in 
anticipation of another CALL. The end of a subroutine, 
which is signaled by a return instruction (RET or RETI), 
causes the stack pointer to be decremented and the 
contents of the resulting register pair to be transferred 
to the program counter. 

Since the program counter's addresses are 11 bits long, 
two bytes or registers must be used to store a single ad- 
dress. Thus, the 16-byte program counter stack permits 
up to a total of 8 levels of subroutine nesting without 
overflowing the stack. If overflow does occur, the 
deepest address stored (locations 8 and 9) will be over- 
written and lost since the stack pointer overflows from 
111 to 000. It also underflows from 000 to 111. If a parti- 
cular application does not require 8 levels of nesting, 
tthe unused portion of the program counter stack may 
be used as any other indirectly addressable RAM loca- 
tion. For example, if only 3 levels of subroutine nesting 
are used, then only locations 8-13 need be reserved for 
the program counter stack, and locations 14-23 can be 
used for data storage. 



8 LEVEL STACK 

OR 

USER RAM 

16x8 



WORKING 

REGISTERS 

8x8 



ADDRESSED 
INDIRECTLY 
THROUGH 
R0 OR R1 



DIRECTLY 
ADDRESSABLE 



DATA MEMORY MAP 
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INPUT/OUTPUT 

The 8022 has 26 lines which can be used for digital input 
or output functions. These lines are organized as 3 ports 
of 8 lines, each of which serve as either inputs, outputs, 
or bidirectional ports, and 2 test inputs which can alter 
program sequences when tested by conditional jump in- 
structions. 

Ports 1 and 2 have identical operating characteristics 
and are both quasi-bidirectional. That is, each line may 
serve as an input, an output, or both. Data written to 
these ports is statically latched and remains unchanged 
until rewritten. As inputs, these lines are non-latching; 



i.e., inputs must be present until read by an input in- 
struction. Inputs are fully TTL compatible and all out- 
puts will drive at least one standard TTL load. Two lines 
of port 1 (P10 and P11) are designated as high current 
drive lines and have the ability to sink 7 mA. In addition, 
these pins may be paralleled for 14 mA output if the out- 
put logic states are always the same. The high current 
output lines eliminate the need for discrete transistors 
in many applications. 

The lines of ports 1 and 2 are quasi-bidirectional 
because of their output structure which allows them to 
be used as inputs, outputs, or both, even though as out- 
puts they are statically latched. 



=5KQ > =50KQ 




I/O PIN 
PORTS 1 
AND 2 



WRITE 
PULSE 



QUASI-BIDIRECTIONAL PORT STRUCTURE 



Each line is continuously pulled up to +5V through a 
relatively high impedance device (~50 kQ). This pullup is 
sufficient to provide the source current for a TTL high 
level, yet can be pulled low by a standard TTL gate, thus 
allowing the same pin to be used both as an input and 
output. When writing a "0" or low value to these ports, a 
low impedance device (~300Q) overcomes the high 
pullup and provides TTL current sinking capability. 
When writing a "1", a large current is momentarily sup- 
plied through a relatively low impedance device (~5kQ) 
to allow a fast data transfer. After a short time (less than 
one instruction cycle) the low impedance device is shut 
off and the small pullup maintains the "1" level indefi- 
nitely. In this situation, an input device capable of over- 
riding the small amount of sustaining current supplied 
by the pullup device can be read. (Alternatively, the data 
written en be read.) So, by writing a "1" to any particular 
pin that pin can serve either as a true high-level latched 
output pin, or as just a pullup resistor on an input. This 
allows maximum user flexibility in selecting his input or 
latched output lines, with a minimum of external 
components. 



PORT COMPARATOR INPUTS 



Port has been modified from the standard quasi- 
bidirectional structure to allow an optional open drain 
configuration with comparator inputs. The low imped- 
ance pullup device has been eliminated and the high im- 
pedance pullup is optional. Thus, the user can choose 
via a mask programmable selection each line of port to 
be either quasi-bidirectional with a high impedance or 
true open-drain. The open drain configuration allows the 
line to sink current through the low impedance pulldown 
device or to float in the high output state. More impor- 
tantly, the open drain configuration makes port very 
easy to drive when it is used as inputs. The input cir- 
cuitry for each line of port includes a voltage com- 
parator which amplifies the voltage difference between 
the input port line and the port threshold reference pin 
(V TH ). The voltage gain of the comparator is sufficient to 
sense a 100 mV input differential withn the range V ss to 
V cc /2. 



8022 



INTERNAL 




D 






Q 
S 






+ 5V 




BUS 




D 
FLIP- 
FLOP 

CLK 










>=50KS 


I/O PIN 
PORTO 




„„ 












1 1 






WRITE 












i 




PULSE 




















Vth 










IN ' ^N 





















PORT I/O STRUCTURE 



If V TH is allowed to float, it will bias itself to the digital 
switch point of the other ports, and port behaves as a 
set of normal digital inputs. However, by biasing V TH , 
the switch point can be both tightly controlled and ad- 
justed. Common uses for this would include high noise 
margin inputs (V cc /2), unusual logic level inputs as from 
a diode isolated keyboard, analog channel expansion, 
and direct capacitive touchpanel interface. The compar- 
ator action is automatic and the port is read just as any 
other port. 

In addition to the 26 digital I/O lines contained on-board 
the 8022, a user can obtain additional I/O lines by utiliz- 
ing the Intel® 8243 I/O expander chip or standard TTL 
The 8243 interfaces to 4 port lines of the 8022 (lower half 
of port 2) and is strobed by the PROG line of the 8022. 




I/O EXPANDER INTERFACE 



A 4-bit transfer from a port to the lower half of the ac- 
cumulator sets the most significant four bits to zero. 
Each transfer consists of two 4-bit nibbles. The first 
contains the "opcodes" and port address, and the sec- 
ond contains the actual 4 bits of data. A high-to-low tran- 
sition of the PROG line indicates that address is present 
while a low-to-high transition indicates the presence of 
data. 

TEST AND INTERRUPT INPUTS 

In addition to the 24 general purpose I/O lines which 
comprise ports 0, 1, and 2, the 8022 has two inputs 
which are testable via conditional jump instructions, TO 
and T1. These pins allow inputs to cause program 
branches without the necessity to load an input port in- 
to the accumulator. TO and T1 have other functions as 
well. 

The Test pin serves as an external interrupt input as 
well as a testable input. An interrupt sequence is initi- 
ated by applying a low "0" level input to the TO pin when 
external interrupt is enabled. Interrupt is level triggered 
and active low to allow "WIRE ORING" of several inter- 
rupt sources at the input pin. When an interrupt is 
detected, it causes a "jump to subroutine" at location 3 
in program memory as soon as all other cycles of the 
current instruction are complete. At this time, the pro- 
gram counter contents are saved in the program counter 
stack, but the remaining status of the processor is not. 
Unlike the 8048, the 8022 does not contain a program 
status word. Thus, when appropriate, the carry and aux- 
iliary carry flags are saved in software, as the accumu- 
lator is. The routine shown below saves the accumulator 
and the carry flags in only four bytes. 



The 8243 contains four 4-bit I/O ports which serve as ex- 
tensions of the on-chip I/O and are addressed as ports 
4-7. The following operations may be performed on 
these ports: 

1. Transfer Accumulator to Port 

2. Transfer Port to Accumulator 

3. And Accumulator to Port 

4. Or Accumulator to Port 



Instructions Bytes 

MOV R6,A 1 

CLR A 1 

DA A 1 

MOV R7,A 1 



Comments 

;save accumulator 
;clear accumulator 
;convert carry flags into sixes 
;save status of carry flags 



The end of an interrupt service subroutine is marked by 
the execution of a Return from Interrupt instruction 
(RETI). Prior to returning from the interrupt subroutine 
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however, the status of the accumulator and the carry 
flags are restored in software. The following routine 
restores the status of the accumulator and the carry 
flags, which was previously saved, in five bytes. 



Instructions Bytes 



MOV A,R7 
Add A,#0AAH 
MOV A,R6 
RETI 



Comments 

;restore carry flags status to 
;accumulator and set/clear carry flags 
;restore accumulator 
;return 



The interrupt system is single level in that once an inter- 
rupt is detected, all further interrupt requests are ig- 
nored until execution of a RETI re-enables the interrupt 
input logic. This sequence holds true also for an internal 
interrupt generated by timer overflow. If an external in- 
terrupt and an internal timer/counter generated interrupt 
are detected at the same time, the external source will 
be recognized. If needed, a second external interrupt 
can be created by enabling the timer/counter interrupt, 
loading FFH in the counter (one less than terminal 
count) and enabling the event counter mode. A low-to- 
high transition on the T1 input will then cause an inter- 
rupt vector to location 7. 

The Test 1 pin, in addition to being a testable input, 
serves two other important functions. It can be used as 
an input pin to the external event counter, as previously 
mentioned, and it can be used to detect the zero cross- 
ing point of slow moving AC signals. Execution of the 
STRT CNT instruction puts the T1 pin in the counter in- 
put mode by connecting T1 to the counter and enabling 
the counter. Subsequent low-to-high transitions on T1 
will cause the counter to increment. Note that this 
operation differs from the rest of the MCS-48 devices, 
which increment the counter on high-to-low transitions. 
This change was made on the 8022 to take advantage of 
the accuracy of the rising edge detection on the zero 
cross circuitry. The maximum rate at which the counter 
may be incremented is once per three instruction cycles 
(every 30 ^s when using a 3 MHz crystal) — there is no 
minimum frequency. 

In addition to serving as a testable input and as the 
counter input, the T1 pin has special circuitry to detect 
when an AC signal crosses its average DC level. When 
driven directly, this pin responds as a normal digital in- 
put. To utilize the zero cross detection mode, an AC 
signal of approximately 1-3 VAC p-p magnitude and a 
maximum frequency of 1 kHz is coupled through an ex- 
ternal capacitor (1 /uF) to the T1 pin. 




8022 
INTERPRETATION 



AC SOURCE 1 1 |T| • — ^ <v — ^° — T0 T1/EVENT COUNTER 

1 mF I ^ 




ZERO-CROSS DETECTION 



The internal digital state is sensed as a zero until the ris- 
ing edge crosses the DC average level, when it becomes 
a one. This is accomplished by the self-biasing high 
gain amplifier which is included in the T1 input. This cir- 
cuit biases the T1 input exactly at its switching point, 
such that a small change will cause a digital transition 
to occur. This digital transition takes place within 5 
degrees of the zero point. The digital value of T1 remains 
a one until the falling edge of the AC input drops approx- 
imately 100 mV below the switching point of the rising 
edge (100 mV below the zero point, if the digital transi- 
tion occurred exactly at the zero point). The 100 mV off- 
set is created by hysterisis and eliminates chattering of 
the internal signal caused by the external noise. 

The zero cross detection capability allows the user to 
make the 60 Hz power signal the basis for this system 
timing. All timing routines, including time-of-day, can be 
implemented using the zero cross detection capability 
of T1 and its conditional jump instructions. In addition, 
the zero cross detection feature can be used in conjunc- 
tion with the timer interrupt to interrupt processing at 
the zero voltage point. This enables the user to control 
voltage phase sensitive devices such as triacs and 
SCRs, and to use the 8022 in applications such as shaft 
speed and angle measurement. 

ANALOG TO DIGITAL CONVERTER 

The 8022 contains on-chip a complete hardware imple- 
mentation of an 8-bit analog to digital (A/D) converter 
with two multiplexed analog inputs. The A/D converter 
utilizes a successive approximation technique to pro- 
vide an updated conversion once every four instruction 
cycles (i.e., once every 40 ps) with a minimum of required 
software. 

The A/D converter consists of four main parts, the input 
circuitry, a series string of resistors, a voltage compar- 
ator, and the successive approximation logic. The two 
analog inputs are multiplexed on-chip and selected via 
software by the SEL AN0 and SEL AN1 instructions. Be- 
sides selecting one of the analog inputs, these instruc- 
tions restart the conversion sequence which operates 
continuously. Restarting a conversion sequence deletes 
the conversion in progress but does not effect the result 
of the previous conversion which is stored in the conver- 
sion result register. The continuous operation of the A/D 
converter saves program space and time by allowing the 
user obtain multiple readings from a given input with 
only one select instruction. To obtain a valid conversion 
reading, the user must provide the analog input signal 
no later than the beginning of the select instruction 
cycle. The analog input is then sampled by the A/D con- 
verter and maintained internally. This voltage becomes 
one input to the voltage comparator which amplifies the 
difference between the analog input and the voltage tap 
on the series resistor string. 

The series resistor string is connected between the A/D 
reference pin (V ARE f) and ground (AV SS ). It is comprised 
of 256 identical resistors which divide the voltage bet- 
ween these two pins into 256 identical voltage steps. 
This configuration gives the converter its inherent 
monotonicity. The range of V ARE fr in which full 8-bit 
resolution can be provided is between V cc /2 and V cc . 



6-30 



8022 



Thus, the user is given a minimum voltage range from 
ground to Mqq)2 and a maximum range from ground to 
Vcc over which 8-bit resolution is insured. 
The voltage tap on the series resistor string is selected 
by the resistor ladder decoder. This decoder is driven by 
the 8-bit successive approximation register (SAR). Each 
bit of the SAR is set in succession MSB to LSB and a 
voltage comparison between the selected resistor lad- 
der voltage and the analog input voltage is performed 
after the setting of each bit. The result of each com- 
parison determines whether the particular bit will re- 
main set or be reset. All comparisons are performed 
automatically by the on-chip A/D hardware. At the end of 
8 comparisons the SAR contains a valid digital result 
which is then latched into the conversion result register 
(CRR). The RAD instruction (read A/D) loads the conver- 
sion result from the CRR to the accumulator of the 8022. 

As mentioned previously, the software and time re- 
quired to perform an A/D conversion is optimized by the 
8022's on-chip A/D converter configuration. Typical soft- 
ware for reading two sequential A/D conversions and 
storing them in data memory is shown below: 

;Starts conversion of ANO input 

;Set up memory pointer 

;First conversion value to accumulator 

;Store first conversion value 
;lncrement memory location 
;Second conversion value to accumulator 



Note that the second conversion occurs without a sec- 
ond select instruction being used. Rather, the con- 
tinuous operation of the A/D converter provides an up- 
dated digital value 4 instruction cycles after the first. 



First 


SELANO 


Conversion 


MOV R0,#24 


50 ^s 


RAD 


4 bytes 




Second 


MOV@R0,A 


Conversion 


INC R0 


40 hS 


RAD 


3 bytes 





To insure maximum accuracy from the A/D converter, 
separate power supply pins (AV cc and AV SS ) and a sub- 
strate pin (SUBST) have been provided. Supplying the 
power supply pins with a well filtered and regulated 
voltage supply minimizes the effect of power supply 
variance and system noise. The substrate pin should be 
bypassed to ground through a 500 pF to 0.001 ^F capaci- 
tor. 



ANALOG MULTIPLEXER 




INTERNAL BUS 



A/D CONVERTER BLOCK DIAGRAM 




R=15K 
RESISTOR 




(L VALUE TO BE DETERMINED) 
INDUCTOR 




CRYSTAL 

FREQUENCY REFERENCE OPTIONS 



TTL 
GATE 



-r> 
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OSCILLATOR AND CLOCK 

The 8022 contains its own on-board oscillator and clock 
circuit, requiring only an external timing control ele- 
ment. This control element can be a crystal, inductor, 
resistor, or clock in. The capacitor normally required in 
resistor or inductor timing control operation is inte- 
grated onto the 8022. All internal time slots are derived 
from the external element, and all outputs are a function 
of the oscillator frequency. Pins X1 and X2 are used to 
input the particular control element. An instruction 
cycle consists of 10 states, and each state is a time slot 
of 3 oscillator periods. Therefore, to obtain a 10 ^s 
instruction cycle, a 3 MHz crystal should be used. 

TIMER/COUNTER 

An interval timer/counter is available to enable the user 
to keep track time elapsed or number of events occurred, 
during normal program execution and flow. 

By a MOV T,A instruction, the contents of the accumu- 
lator are loaded to the timer. At the STRT T command an 
internal prescaler is zeroed and thereafter increments 
once each 30 input clocks (once each single cycle in- 
struction, twice each double cycle instruction). The pre- 
scaler is a divided by 32. At the (1 1 1 1 1) to (00000) transi- 
tion the timer is incremented. The timer is 8 bits and an 
overflow (FFH) to (00H) timer flag is set along with the 
timer interrupt, if enabled. A conditional branch instruc- 
tion (JTF) is available for testing this flag, the flag being 
reset each test. This instruction must also be used to in- 
itialize the timer overflow flag after a RESET instruction, 
as RESET does not perform this function. Total count 
capacity for the timer is 2 8 x 2 5 =s=8192 or 81.9 ms at a 10 
ps cycle time. Contents of the timer are moved to the ac- 
cumulator by the MOV A,T instruction without disturb- 
ing the counting process. 

The timer may also be used as an event counter. After a 
STRT CNT command, the 8022 will respond to a low-to- 
high transition on the Test 1 pin by incrementing the 
timer. Transitions can occur no faster than once each 
three instruction cycles. 

The timer and event functions are exclusive. Counting 
or timing may be started or stopped (STOP TCNT) at will. 



CPU 

The 8022 CPU has arithmetic and logical capability. A 
wide variety of arithmetic and logic instructions may be 
exercised, which affect the contents of the accumu- 
lator, and/or direct or indirect scratchpad locations. Pro- 
visions have been made for simplified BCD arithmetic 
capability through the use of the DAA, SWAP A, and 
XCHD instructions. In addition, MOVP A,@A allows 
table lookup for display formatting and constants. Jump 
conditions such as zero, not zero refer to the accumu- 
lator contents at the time of the condition. 



RESET 

The 8022 may be used in systems with poorly regulated 
and noisy power supplies. A useful feature is to sense 
when the power supply dips and quickly recovers, and 
do a reset to prevent continued operation with incorrect 
data. This feature may be implemented on the 8022 by 
connecting a diode between the RESET node and 
ground. 

Including the diode in the reset circuitry forces a reset 
to occur if the power supply experiences a very sudden 
voltage glitch. Specifically, if the power supply drops 
approximately 1.5V and recovers after at least a few 
nanoseconds, a reset will occur. Without the diode, a 
power supply interruption of less than 1 ms will not 
cause a power-on reset. 



v C c 




POWER ON RESET 



Printed in U.S.A./TI4I/0678/200 DLR 
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ROM AND I/O EXPANDER 






"V^o* 



ij t'f 



2K x 8 ROM 
2 Eight Bit I/O Ports 
Internal Address Latch 
I/O Lines Individually 
Input or Output 



Assignable as 



■ Single 5V Supply 
□ 40 Pin DIP 

o Completely Interchangeable With 8755 
EPROM 



The 8355 is designed to expand both the program memory and I/O capability of the MCS-48 T " single component 
microcomputers (the 8748, 8048 and 8035). This expander increases program memory by 2K words and adds 16 I/O lines to 
the basic microcomputer without the necessity of any additional components. The completely interchangeable 8755 light 
erasable EPROM and 8355 mask programmed ROM provide a simple transition from prototype to production. Both 
versions operate from a single 5V supply and are totally speed compatible with the MCS-48 microcomputers. 

The 16 I/O lines are addressed as 2 eight bit I/O ports, yet single lines can be individually designated as input or as output 
under software control. Outputs are double buffered to prevent any output glitches. 



PIN CONFIGURATION 



BLOCK DIAGRAM 



CEC 2 

clkC 
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8355 FUNCTIONAL PIN DEFINITION 



Symbol 

ALE 



AD0-7 



A8-10 



CE 
CE 



IO/M 



RD 



IOW 



Function 

When ALE (Address Latch Enable) is 
high, AD0-7, IO/M, A 8 -io. CE, and CE 
enter address latched. The signals 
(AD, IO/M, A 8 -io, CE, CE) are latched 
in at the trailing edge of ALE. 

Bi-directional Address/Data bus. The 
lower 8-bits of the ROM or I/O 
address are applied to the bus lines 
when ALE is high. 

During an I/O cycle, Port A or B are 
selected base d on the latched value of 
ADo- If RD or IOR is low when latched 
Chip Enables are active, the output 
buffers present data on the bus. 

These are the high order bits of the 
ROM address. They do not affect I/O 
operations. 

Chip Enable Inputs: CE is active k>w 
and CE is active high . The 8355 can be 
accessed only when BOTH Chip 
Enables are active at the time the ALE 
signal latches them up. If either Chip 
Enable input is not active, the ADn-7 
and READY outputs will be in a high 
impedance state. 

If the latched IO/M is high when RD is 
low, the output data comes from an 
I/O port. If it is low the output data 
comes from the ROM. 

If the latched Chip Enables are active 
when RD goes low, the ADr>7 output 
buffers are enabled and output either 
the selected ROM location or I/O 
port. When both RD and fOR are high, 
the ADf>7 output buffers are tri- 
stated. 

If the latc hed C hip Enables are active, 
a low on IOW causes the output port 
pointed to by the latched value of AD 
to be written with the data on ADq-7. 
The state of IO/M is ignored. 



Symbol 

CLK 



READY 



PA 



0-7 



PBo-7 



RESET 



IOR 



V C C 
V S S 



Function 

The CLK is used to force the READY 
into its high impedance state after it 
has been forced low by CE low, CE 
high and ALE high. 

Ready is a tri-state output controlled 
by CE, CE, ALE and CLK. READY is 
forced low when the Chip Enables are 
active during the time ALE is high, 
and remains low until the rising edge 
of the next CLK (see Figure 4). 

These are general purpose I/O pins. 
Their input/output direction is deter- 
mined by the contents of Data 
Direction Register (DDR). Port A is 
selected for write operations when 
the Chip Enables are active and IOW 
is low and a was previously latched 
from ADo. 

Read operation is selected by fOR low 
when the Chip is enabled and ADq 
low. 

Alternately, IO/M high and RD low 
may be used in place of IOR when the 
chip is enabled and ADo is low to 
allow reading from a port. 

This general purpose I/O port is 
identical to Port A except that it is 
selected by a 1 latched from ADo. 

An input high on RESET causes all 
pins in Ports A and B to assume input 
mode. 

When t he C hip Enables are active, a 
low on IOR will output the sele cted 
I/O port onto the AD bus. IOR low 
performs the same function as the 
combination IO/M high and RD low. 

+5 volt supply. 

volt supply. 
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FUNCTIONAL DESCRIPTION 



Program Memory — The 8355 contains an 8-bit address 
latch which allows it to interface directly to MCS- 
48 Microcomputers without additional hardware. Program 
memory is accessed by applying 1 1 bits of_address to the 
A - A 10 inputs and a low level on the IO/M and CE inputs 
then latching these inputs with ALE. The CE input serves 
to select one of several possible 8355s in a system 
and the IO/M signal indicates that a subsequent read 
operation will be from program memory. While ALE is high 
the Ao - A10, IO/M, and CE inputs are allowed into the 
8355 and when ALE is brought low, these inputs are 
latched. If the latched conditions indicate that a program 
memory fetch is to occur, a low level on RD will cause the 
data to be outputted on the data bus. 



A-| Ao Selection 

Port A 

1 Port B 

1 DDRA 
1 1 DDRB 



I/O Port Addressing 



I/O Ports — The I/O lines are organized as t wo 8- bit s tatic 
ports which can be read or written using the IOR and IOW 
control lines. Associated with each port is an 8-bit Data 
Direction Register (DDR) which serves to define each of 
the 8 lines of the port as either an input or an output. A"1" 
bit in the DDR sets the corresponding port bit to the output 
mode while a "0" designates the input mode. The two least 
significant bits of the latched address (A , A^ address the 
two-J/O ports and their associated DDR's. 



ALE 

PSEN 

WR 

8048 rd 

BUS 
P20P23 



7^ 



ALE 2KXS 



IOW 

l0R ROM/ 
PROM 

WITH 
A /<V 7 I/O 
8355/ 
8755 

A a' A io 



<=3ET>' 



Interface to MCS-48"" Microcomputers 
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ABSOLUTE MAXIMUM RATINGS' 



Temperature Under Bias 0°Cto+70°C 

StorageTemperature -65°Cto+150°C 

Voltage on Any Pin 

With Respect to Ground -0.3Vto+7V 

Power Dissipation 1.5W 



*COMMENT: Stresses above those listed under "Absolute 
Maximum Ratings" may cause permanent damage to the 
device. This is a stress rating only and functional opera- 
tion of the device at these or any other conditions above 
those indicated in the operational sections of this specifi- 
cation is not implied. Exposure to absolute maximum 
rating conditions for extended periods may affect device 
reliability. 



D.C. CHARACTERISTICS (T A 


= 0°C to 70°C; V cc = 5V ± 5%) 






SYMBOL 


PARAMETER 


MIN. 


MAX. 


UNITS 


TEST CONDITIONS 


V|L 


Input Low Voltage 


-0.5 


0.8 


V 


V CC = 5.0V 


V| H 


Input High Voltage 


2.0 


Vcc+0.5 


V 


V CC = 5.0V 


Vol 


Output Low Voltage 




0.45 


V 


Iol = 2mA 


Voh 


Output High Voltage 


2.4 




V 


Iqh = -400/xA 


l|L 


Input Leakage 




10 


/xA 


Vin = V C c to 0V 


'lo 


Output Leakage Current 




±10 


MA 


0.45V <Vqut <V CC 


•cc 


Vqc Supply Current 




180 


mA 





A.C. CHARACTERISTICS (T A = o°cto 70°c, v cc = 5V ± 5%) 



SYMBOL 


PARAMETER 


MIN. 


MAX. 


UNITS 


TEST CONDITIONS 


tCYC 


Clock Cycle Time 


320 




ns 




Tl 


CLK Pulse Width 


80 




ns 


Cload = 150 pF 


T 2 


CLK Pulse Width 


120 




ns 




tf.t r 


CLK Rise and Fall Time 




30 


ns 




tAL 


Address to Latch Set Up Time 


50 




ns 




tLA 


Address Hold Time after Latch 


80 




ns 




tLC 


Latch to READ/WRITE Control 


100 




ns 




tRD 


Valid Data Out Delay from READ Control 




170 


ns 




tAD 


Address Stable to Data Out Valid 




400 


ns 


1 50 pF Load 


tLL 


Latch Enable Width 


100 




ns 




tRDF 


Data Bus Float after READ 





100 


ns 




tCL 


READ/WRITE Control to Latch Enable 


20 




ns 




tec 


READ/WRITE Control Width 


250 




ns 




tow 


Data In to WR ITE Set Up Time 


150 




ns 




tWD 


Data In Hold Time After WRITE 


10 




ns 




twp 


WRITE to Port Output 




400 


ns 




tpR 


Port Input Set Up Time 


50 




ns 




tRP 


Port Input Hold Time 


50 




ns 




tRYH 


READY HOLD TIME 





160 


ns 




tARY 


ADDRESS (CE) to READY 




160 


ns 




tRV 


Recovery Time between Controls 


300 




ns 




tRDE 


Data Out Delay from READ Control 


10 




ns 
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CLOCK SPECIFICATION FOR 8355. 
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ROM READ AND I/O READ AND WRITE. 
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<CE=1). (CE=0) 




WAIT STATE TIMING (READY = 0). 



A. INPUT MODE 



RDOR 
IOR 



v r 



PORT 
INPUT 



31 



X 



DATA" 
BUS 



oc 



B. OUTPUT MODE 



\ 



/ 



PORT 
OUTPUT 



x: 



GLITCH FREE 
OUTPUT 



DATA* 
BUS 



X 



X 



•DATA BUS TIMING IS SHOWN IN FIGURE 3. 



I/O PORT TIMING. 




8755A 
16,384 BIT EPROM WITH I/O 



□ 2048 Words x 8 Bits 
a Single +5V Power Supply (Vcc) 
b U.V. Erasable and Electrically Repro- 
grammable 
Internal Address Latch 



ei 2 General Purpose 8 bit I/O Ports 

o Each I/O Port Line Individually 

Programmable as Input or Output 
Multiplexed Address and Data Bus 
m 40 Pin DIP 



The 8755A is designed to expand both the program memory and I/O capability of the MCS-48™ single component 
microcomputers (the 8748, 8048 and 8035). This expander increases program memory by 2K words and adds 1 6 I/O lines to 
the basic microcomputer without the necessity of any additional components. The completely interchangeable 8755A 
light erasable EPROM and 8355 mask programmed ROM provide a simple transition from prototype to production. Both 
versions operate from a single 5V supply and are totally speed compatible with the MCS-48 microcomputers. 

The 16 I/O lines are addressed as 2 eight bit I/O ports, yet single lines can be individually designated as input or as output 
under software control. Outputs are double buffered to prevent any output glitches. 



PIN CONFIGURATION 



BLOCK DIAGRAM 



PROG AND CE £ 

CEC 

CLK C 

RESET C 

HjdC 

READY C 

IO/M C 

iOR L 

RD C 

iow C 
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8755A FUNCTIONAL DESCRIPTION 

Symbol 



ALE 



AD 



0-7 



v 8-10 



CE/PROG 
CE 



IO/M 



RD 



IOW 



CLK 



READY 



PA 



0-7 



Function 

When Address Latch Enable goes 
high, AD0-7, IO/M, A8-10, CE, and CE 
enter the address latches. The signals 
(AD, IO/M, A8-10, CE) are latched in at 
the trailing edge of ALE. 

Bi-directional Address/Data bus. The 
lower 8-bits of the PROM or I/O 
address are applied to the bus lines 
when ALE is high. 

During an I/O cycle, Port A or B are 
selected based on th e latched value of 
AD . If RD or IOR is low when the 
latched Chip Enables are active, the 
output buffers present data on the 
bus. 

These are the high order bits of the 
PROM address. They do not affect 
I/O operations. 

CHIP ENABLE INPUTS: CEis active 
low and CE is active high . Both chip 
enables must be active to permit 
accessing the PROM. CE is also used 
as a programming pin (see section on 
programming). 

If the latched IO/M is high when RD is 
low, the output data comes from an 
I/O port. If it is low the output data 
comes from the PROM. 

If the latched Chip Enables are active 
when RD goes low, the ADq-7 output 
buffers are enabled and output either 
the selected PROM lo catio n or I/O 
port. When both RD and IOR are high, 
the AD0-7 output buffers are tri- 
stated. 

If the latched Chip Enables are active, 
a low on IOW causes the output port 
pointed to by the latched value of ADo 
to be written with the data on AD0-7. 
The state of IO/M is ignored. 

The CLK is used to force the READY 
into its high impedance state after it 
has been forced low by CE low, CE 
high, and ALE high. 

READY is a 3-state output controlled 
by CE, CE, ALE and CLK. READY is 
forced low when the Chip Enables are 
active during the time ALE is high, 
and remains low until the rising edge 
of the next CLK (see Figure 2.). 

These are general purpose I/O pins. 
Their input/output direction is deter- 
mined by the contents of Data 
Direction Register (DDR). Port A is 
selected for write operations when 
the Chip Enables are active and IOW 
is low and a was previously latched 
from ADq. 



PB 



0-7 



RESET 



IOR 



'CC 



'DD 



Rea d operation is selected by either 
IOR low and active Chip Enables and 
ADq low, or IO/M"high, RD low, active 
Chip Enables, and ADo low - 
This general purpose I/O port is 
identical to Port A except that it is 
selected by a 1 latched from ADo- 

In normal operation, an input high on 
RESET causes all pins in Ports A and 
B to assume input mode (clear DDR 
register). 

When t he C hip Enables are active, a 
low on^iOR will output the selected 
I/O port onto the AD bus. IOR low 
performs the same function as the 
combination of IO/M high and RD 
low. W hen IOR is not used in a 
system, IOR should be tied to Vqc 
("1"). 

+5 volt supply. 
Ground Reference. 

V DD is a programming voltage, and 
with the 8755A it is tied to +5V when 
the 8755A is being read. 

For programming, a high voltage is 
supplied with Vq D . = 25V, typical. 



FUNCTIONAL DESCRIPTION 
PROM Section 

The 8755A contains an 8-bit address latch which allows it 
to interface directly to MCS-48 and MCS-85 Microcom- 
puters without additional hardware. 

The PROM section of the chip is addressed by the 1 1-bit 
address and CE. The address, CE and CE are latched into 
the address latches on the falling edge of ALE. If the 
latched Chip Enables are active and IO/M is low when RD 
goes low, the contents of the PROM location addressed by 
the latched address are put out on the AD0-7 lines. 

I/O Section 

The I/O section of the chip is addressed by the latched 
value of ADQ.-J. Two 8-bit Data Direction Registers 
determine the input/output status of each pin in the 
corresponding port. A specifies an input mode, and a 1 
specifies an output mode. The table summarizes port and 
DDR designation. Contents of the DDR's cannot be read. 

AD-i ADq Selection 

Port A 

1 Port B 

1 Port A Data Direction Register (DDR A) 
1 1 Port B Data Direction Register (DDR B) 
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When IOW goes low and the Chip Enables are active, the 
data on the AD is written into I/O port selected by the 
latched value of ADo-v During this operation all I/O bits of 
the selected port are affected, regardless of their I/O mode 
and the state oflO/M. The actual output level does not 
change until IOW returns high, (glitch free output). 

A port can be read out when the latched Chip Enables are 
active and either RD goes low with IO/M high, or IOR goes 
low. Both input and output mode bits of a selected port will 
appear on lines AD0-7. 

To clarify the function of the I/O Ports and Data Direction 
Registers, the following diagram shows the configuration 
of one bit of PORT A and DDR A. The same logic applies to 
PORT B and DDR B. 



8755A 
ONE BIT OF PORT A AND DDR A: 



/\ 



CLR CLK 



WRITE DDR A 



V 7 



d: 



READ PA 

WRITE PA = liOW'O) » (CHIP ENABLES ACTIVE) • {PORT A ADDRESS SELECTED) 
WRITE DDR A • IIO_W=0) • (CHIP ENABLES ACTIVE) • (DDR A ADDRESS SELECTED) 
READ PA = {[(IO/M'1) • (RO=0)]* (IOR»0)} • (CHIP ENABLES ACTIVE) • (PORT A ADDRESS SELECTED) 



Note that hardware RESET or writing a zero to the DDR 
latch will cause the output latch's output buffer to be 
disabled, preventing the data in the Output Latch from 
being passed through to the pin. This is equivalent to 
putting the port in the input mode. Note also that the data 
can be written to the Output Latch even though the Output 
Buffer has been disabled. This enables a port to be 



initialized with a value prior to enabling the output. 

The diagram also shows that the contents of PORT A and 
PORT B can be read even when the ports are configured 
as outputs. 

ERASURE CHARACTERISTICS 

The erasure characteristics of the 8755A are such that 
erasure begins to occur when exposed to light with 
wavelengths shorter than approximately 4000 Angstroms 
(A). It should be noted that sunlight and certain types of 
fluorescent lamps have wavelengths in the 3000-4000A 
range. Data show that constant exposure to room level 
flourescent lighting could erase the typical 8755A in 
approximately 3 years while it would take approximately 1 
week to cause erasure when exposed to direct sunlight. If 
the 8755A is to be exposed to these types of lighting 
conditions for extended periodsof time, opaque labels are 
available from Intel which should be placed over the 8755 
window to prevent unintentional erasure. 

The recommended erasure procedure (see page 3-55) for 
the 8755A is exposure to shortwave ultraviolet light which 
has a wavelength of 2537 Angstroms (A). The integrated 
dose (i.e., UV intensity X exposure time) for erasure 
should be a minimum of 15W-sec/cm 2 . The erasure time 
with this dosage is approximately 15 to 20 minutes using 
an ultraviolet lamp with a 12000uW/cm2 power rating. The 
8755A should be placed within one inch from the lamp 
tubes during erasure. Some lamps have a filter on their 
tubes and this filter should be removed before erasure. 

PROGRAMMING 

Initially, and after each erasure, all bits of the EPROM 
portions of the 8755A are in the "1" state. Information is 
introduced by selectively programming "0" into the 
desired bit locations. A programmed "0" can only be 
changed to a "1" by UV erasure. 

The 8755A can be programmed on the Intel® Universal 
PROM Programmer (UPP), and the PROMPT'" 80/85 and 
PROMPT-48™ design aids. The appropriate programming 
modules and adapters for use in programming both 
8755A's and 8755's are shown in the table below. 



intel®8755/8755A Programming Module 
Cross Reference 



MODULE NAME 


USE WITH 


WILL PROGRAM 


UPP 855 


UPP 111 


8755 


UPP 955 


UPP 


8755A 


UPP UP1"" 


UPP 955 


8755 


UPP UP2' 4 ' 


UPP 855 


8755A 


PROMPT™ 875 


PROMPT 80/85 121 


8755 


PROMPT 975 


PROMPT 80/85 


8755A 


PROMPT 475 


PROMPT 48 13 ' 


8755A 



1. Intel's Universal PROM Programmer module, described on p. 13-45 of 
the Intel 1977 Data Catalog. 

2. Described on p. 13-56 of 1977 Data Catalog. 

3. Described on p. 13-51 of 1977 Data Catalog. 

4. Special adaptor socket. 
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ABSOLUTE MAXIMUM RATINGS* 



Te'mperature Under Bias -10°C to +70°C 

Storage Temperature -65°Cto+150°C 

Voltage on Any Pin 

With Respect to Ground -0.5Vto+7V 

Power Dissipation , 1.5W 



'COMMENT: Stresses above those listed under "Absolute 
Maximum Ratings" may cause permanent damage to the 
device. This is a stress rating only and functional opera- 
tion of the device at these or any other conditions above 
those indicated in the operational sections of this specifi- 
cation is not implied. Exposure to absolute maximum 
rating conditions for extended periods may affect device 
reliability. 



D.C. CHARACTERISTICS (T A 


= 0°C to 70°C; V cc = 5V ± 5%) 






SYMBOL 


PARAMETER 


MIIM. 


MAX. 


UNITS 


TEST CONDITIONS 


V|L 


Input Low Voltage 


-0.5 


0.8 


V 




v IH 


Input High Voltage 


2.0 


V CC +0-5 


V 




Vol 


Output Low Voltage 




0.45 


V 


Iol = 2mA 


Voh 


Output High Voltage 


2.4 




V 


Ioh = -400/iA 


Iil 


Input Leakage 




10 


ma 


Vin = v C c to OV 


Ilo 


Output Leakage Current 




+10 


M 


0.45V <V UT <V CC 


•cc 


Vqc Supply Current 




180 


mA 





A.C. CHARACTERISTICS (T A = o°c to 70°c, v cc = 5V ± 5%) 






SYMBOL 


PARAMETER 


MIN. 


MAX. 


UNITS 


TEST CONDITIONS 


tCYC 


Clock Cycle Time 


320 




ns 




Tl 


CLK Pulse Width 


80 




ns 


Cload = 150 pF 


T 2 


CLK Pulse Width 


120 




ns 


(See Figure 3) 


tf.tr 


CLK Rise and Fall Time 




30 


ns 




tAL 


Address to Latch Set Up Time 


50 




ns 




tLA 


Address Hold Time after Latch 


80 




ns 




tLC 


Latch to READ/WRITE Control 


100 




ns 




tRD 


Valid Data Out Delay from READ Control 




170 


ns 




tAD 


Address Stable to Data Out Valid 




400 


ns 


150 pF Load 


tLL 


Latch Enable Width 


100 




ns 




tRDF 


Data Bus Float after READ 





100 


ns 




tCL 


READ/WRITE Control to Latch Enable 


20 




ns 




tec 


READ/WRITE Control Width 


250 




ns 




tDW 


Data In to WRITE Set Up Time 


150 




ns 




tWD 


Data In Hold Time After WR ITE 







ns 




t W p 


WRITE to Port Output 




400 


ns 




tpR 


Port Input Set Up Time 


50 




ns 




tRP 


Port Input Hold Time 


50 




ns 




tRYH 


READY HOLD TIME 





160 


ns 




tARY 


ADDRESS (CE) to READY 




160 


ns 




tRV 


Recovery Time between Controls 


300 




ns 




tRDE 


Data Out Delay from READ Control 


10 




ns 
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FIGURE 3. CLOCK SPECIFICATION FOR 8755A. 
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FIGURE 4. PROM READ, I/O READ, AND WRITE TIMING. 

Please note that CE1 must remain low (or the entire cycle. 
This is due to the (act that the programming enable 
function com mon to this pin will disrupt internal data bus 
levels if CE1 is taken high during the read. 
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A. INPUT MODE 



RDOR 
IOR 



\ t 



PORT 
INPUT 



DATA* 
BUS 



IX 



X 



X 



B. OUTPUT MODE 



IOW 



\ 



/ 



W" 



PORT 
OUTPUT 



GLITCH FREE 
OUTPUT 



X 



DATA* 
BUS 



X 



X 



•DATA BUS TIMING IS SHOWN IN FIGURE 4. 



FIGURE 5. I/O PORT TIMING. 




AA__AA. 



/ V 



FIGURE 6. WAIT STATE TIMING (READY = 0). 
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RAM AND I/O EXPANDER 



a 256 x 8 Static RAM 
M 2 Programmable 8-Bit I/O Ports 
E3 1 Programmable 6-Bit I/O Port 
E3 Internal Address Latch 



S Single 5V Supply 

Ea 40 Pin Dual-ln-Line Package 

□ Programmable 14-Bit Timer/Counter 



The 8155 is designed to expand the data memory, I/O, and timer capability of the MCS-48™ single component 
microcomputers (the 8748, 8048, and 8035). This expander increases data memory by 256 words, adds 22 I/O lines, and 
adds a 14-bit timer/counter to the basic microcomputer without the necessity of any additional components. The 81 56 is an 
8155 with an active high chip enable (CE) input. 

The data memory is a 256x8 static RAM which is speed compatible with all MCS-48 components. The I/O consists of two 
eight-bit ports which can be programmed for either input or output with or without associated handshaking signals and 
processor interrupt requests. An additional 6-bit port functions as an input port, as an output port, or as the source of 
strobes for the two eight-bit ports in the handshake mode. The 1 4-bit programmable timer/counter whose input clock and 
terminal count output are available to the user externally is programmable for several modes of operation. 



PIN CONFIGURATION 



BLOCK DIAGRAM 



p c 3 


c 


1 


^ 40 


3 v cc 


PC„ 


L" 


2 


39 


J pc 2 


TIMER IN 


L" 


3 


38 


3 pc, 


RESET 


C 


4 


37 


3 pc 


PC 6 


c 


5 

6 


36 
35 


3 pb 7 


TIMER OUT 


J ^6 


IO/M 


c 




34 


3 pb 5 


# 


c 


8 


33 


3 pb 4 


RD 


c 


9 


32 


3 pb 3 


WR 


c 


10 


8155/ 31 


3 pb 2 


ALE 


c 


11 


8156 30 


3 pb, 


AD 


£ 


12 


29 


3 pb 


AD, 


c 


13 


28 


3 pa 7 


AD 2 


L" 


14 


27 


3 pa 6 


AD 3 


C 


15 


26 


3 pa 5 


AD 4 


c 


16 


25 


3 PA 4 


AD 5 


c 


17 


24 


D pa 3 


AD 6 


c 


18 


23 


3 pa 2 


AD 7 


c 


19 


22 


D pa, 


V SS 


c 


20 


21 


3 pa 



WR- 
RESET- 



-<C=^> 



256 X8 
STATIC 
RAM 



TIMER CLK 1 



/l P0RT X 

\r-^v> PA ° 7 

PORTB K 



^PORTCk 



-V cc (+5V) 
-V« (0VI 



: 8155 = CE, 8156 = CE 
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8155/8156 FUNCTIONAL PIN DEFINITION 

The following describes the functions of all of the 8155/8156 pins. 



Symbol 

RESET 



AD 



0-7 



CE or CE 



RD 



WR 



ALE 



IO/M 



Function 

The Reset signal is a pulse provided 
by the 8085 to initialize the system. 
Input high on this line resets the chip 
and initializes the three I/O ports to 
input mode. The width of RESET 
pulse should typically be 600 nsec. 
(Two 8085A clock cycle times). 
These are 3-state Address/Data lines 
that interface with the CPU lower 8- 
bit Address/Data Bus. The 8-bit 
address is latched into the address 
latch on the falling edge of the ALE. 
The address can be either for the 
memory section or the I/O section 
depending on the polarity of the IO/M 
input signal. The 8-bit data is either 
written into the chip or Read from the 
chip depending on the status of 
WRITE or READ input signal. 

Chip Enable: On the 8155 , this pin is 
CE and is ACTIVE LOW. On the 81 56 . 
this pin is CE and is ACTIVE HIGH. 

Input low on this line with the Chip 
Enable active enables the ADo-7 
buffers. If IO/M pin is low, the RAM 
content will be read out to the AD bus. 
Otherwise the content of the selected 
I/O port will be read to the AD bus. 

Input low on this line with the Chip 
Enable active causes the data on the 
AD lines to be written to the RAM or 
I/O ports depending on the polarity of 
IO/M. 

Address Latch Enable: This control 
signal latches both the address on the 
ADo-7 lines and the state of the Chip 
Enable and IO/M into the chip at the 
falling edge of ALE. 



Symbol 

PA - 7 (8) 



PB . 7 (8) 



PC - 5 (6) 



TIMER IN 
TIMER OUT 

V C C 
V S S 



Function 

These 8 pins are general purpose I/O 
pins. The in/out direction is selected 
by programming the Command/ 
Status Register. 

These 8 pins are general purpose I/O 
pins. The in/out direction is selected 
by programming the Command/ 
Status Register. 

These 6 pins can function as either 
input port, output port, or as control 
signals for PA and PB. Programming 
is done through the C/S Register. 
When PCrj-5 are used as control 
signals, they will provide the follow- 
ing: ' 

PCO — A INTR (Port A Interrupt) 
PC1 — A BF (Port A Buffer full) 

PC2 — A STB (Port A Strobe) 

PC3 — B INTR (Port B Interrupt) 
PC4 — B BF ( Port B Buffer Full) 
PC5 — B STB (Port B Strobe) 

This is the input to the counter timer. 

This pin is the timer output. This 
output can be either a square wave or 
a pulse depending on the timer mode. 

+5 volt supply. 

Ground Reference. 



IO/Memory Select: This line selects 
the memory if low and selects the I O if 
high. 
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OPERATIONAL DESCRIPTION 

The 8155/8156 includes the following operational 
features: 

• 2K Bit Static RAM organized as 256 x 8 

• Two 8-bit I/O ports (PA & PB) and one 6-bit I/O port 
(PC) 

• 14-bit binary down counter 

The I/O portion contains four registers (Command/ 
Status, PArj-7, PB0-7, PC0-5). The IO/M (lO/Memory 
Select) pin selects the I/O or the memory (RAM) portion. 
Detailed descriptions of memory, I/O ports and timer 
functions will follow. 



The 8-brt_ address on the AD lines, the Chip Enable input, 
and IO/M are all latched on chip atthe falling edge of ALE. 
A low on the IO/M must be provided to select the memory 
section. 



CT(8155) 


\ 

/ 




/ 


\ 


OR 








CE (8156) 




\ 


/ 








IO/M 


\ 


/ 


\ 






) 


~< 




AD 0-7 


X 


ADDRESS 


Y DATA VALID \ ( 




/ 






ALE 


\ 


/ 












RDOR WR 






\ 


/ 



NOTE. FOR DETAILED TIMING DIAGRAM INFORMATION, SEE FIGURE 7 AND A.C. CHARACTERISTICS. 



FIGURE 1. MEMORY READ/WRITE CYCLE. 
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PROGRAMMING OF THE COMMAND/ 
STATUS REGISTER 

The command register consists of eight latches one for 
each bit. Four bits (0-3) define the mode of the ports, two 
bits (4-5) enable or disable the interrupt from port C when 
it acts as control port, and the last two bits (6-7) areforthe 
timer. 

The C/S register contents can be altered at any time by 
using the I/O address XXXXX000 during a WRITE 
operation. The meaning of each bit of the command byte 
is defined as follows: 



READING THE COMMAND/STATUS 
REGISTER 

The status register consists of seven latches one for each 
bit; six (0-5) for the status of the ports and one (6) for the 
status of the timer. 

The status of the timer and the I/O section can be polled by 
reading the C/S Register (Address XXXXX000). Status 
word format is shown below: 



|TM 2 TM, IEB IEA PC 2 PC, PB PA 



I ► DEFINE 



-TIMER COMMAND- 



DEFINES PA0-7 


C 


= INPUT 


DEFINES PB0-7 


1 = OUTPUT 




00 = ALT 1 


DEFINES PCo-5 - 


11 = ALT 2 
01 = ALT 3 




10 - ALT 4 


ENABLE PORT A 
INTERRUPT 


1 = ENABLE 


ENABLE PORT B 


= DISABLE 


INTERRUPT 


_ 





00 = NOP - DO NOT AFFECT COUNTER 

OPERATION 

01 = STOP - NOP IF TIMER HAS NOT STARTED; 

STOP COUNTING IF THE TIMER IS 
RUNNING 

10 = STOP AFTER TC - STOP IMMEDIATELY 

AFTER PRESENT TC IS REACHED (NOP 
IF TIMER HAS NOT STARTED) 

11 = START - LOAD MODE AND CNT LENGTH 

AND START IMMEDIATELY AFTER 
LOADING (IF TIMER IS NOT PRESENTLY 
RUNNING). IF TIMER IS RUNNING, START 
THE NEW MODE AND CNT LENGTH 
IMMEDIATELY AFTER PRESENT TC 
IS REACHED. 



AD 7 AD 6 AD 5 AD 4 AD 3 AD 2 ADi ADo 



M 



B 



TIMER INTE B INTR INTE 



BF 



B 



PORT A INTERRUPT REQUEST 

PORT A BUFFER FULL/EMPTY 
(INPUT/OUTPUT) 

PORT A INTERRUPT ENABLE 

PORT B INTERRUPT REQUEST 

PORT B BUFFER FULL/EMPTY 
(INPUT/OUTPUT) 

PORT B INTERRUPT ENABLED 

TIMER INTERRUPT (THIS BIT 
IS LATCHED HIGH WHEN 
TERMINAL COUNT IS 
REACHED. AND IS RESET TO 
LOW UPON READING OF THE 
C/S REGISTER OR STARTING 
NEW COUNT.) 



FIGURE 2. COMMAND/STATUS REGISTER BIT 
ASSIGNMENT. 



FIGURE 3. COMMAND/STATUS REGISTER STATUS 
WORD FORMAT. 
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INPUT/OUTPUT SECTION 

The I/O section of the 8155/8156 consists of four registers 
as described below. 

• Command/Status Register (C/S) — This register is 
assigned the address XXXXXOOO. The C/S address 
serves the dual purpose. 

When the C/S register is selected during WRITE 
operation, a command is written into the command 
register. The contents of this register are not 
accessible through the pins. 

When the C/S (XXXXXOOO) is selected during a READ 
operation, the status information of the I/O ports and 
the timer become available on the AD0-7 lines. 

• PA Register — This register can be programmed to be 
either input or output ports depending on the 
status of the contents of the C/S Register. Also 
depending on the command, this port can operate in 
either the basic mode or the strobed mode (See timing 
diagram). The I/O pins assigned in relation to this 
register are PArj-7. The address of this register is 
XXXXX001. 

• PB Register — This register functions the same as PA 
Register. The I/O pins assigned are PB0-7. The address 
of this register is XXXXX010. 

• PC Register -This register has the address XXXXX011 
and contains only 6-bits. The 6-bits can be program- 
med to be either input ports, output ports or as control 
signals for PA and PB by properly programming the 
AD 2 and AD3 bits of the C/S register. 

When PC0-5 is used as a control port, 3-bits are 
assigned for Port A and 3 for Port B. The first bit is an 
interrupt that the 8155 sends out. The second is an 
output signal indicating whether the buffer is full or 
empty, and the third is an input pin to accept a strobe 
for the strobed input mode. See Table 1. 

When the 'C port is programmed to either ALT3 or ALT4, 
the control signals for PA and PB are initialized as follows: 



The following diagram shows how I/O PORTS Aand Bare 
structured within the 8155 and 8156: 



CONTROL 


INPUT MODE 


OUTPUT MODE 


BF 
INTR 
STB 


Low 

Low 

Input Control 


Low 

High 

Input Control 



8155/8156 
ONE BIT OF PORT A OR PORT B 




} 



STB 



MULTIPLEXER 
CONTROL 



(4) 



V 

NOTES: 

(1) OUTPUT MODE 

(2) SIMPLE INPUT 

(3) STROBED INPUT. 
READ PORT = (IO/M^1l • (RB-0) • (CE ACTIVE) • (PORT ADDRESS SELECTED) 
WRITE PORT = (IO/M=1) • (WR=0) • (CE ACTIVE) • (PORT ADDRESS SELECTED) 



= 1 FOR OUTPUT MODE 
= 0FOR INPUT MODE 



Note in the diagram that when the I/O ports are 
programmed to be output ports, the contents of the output 
ports can still be read by a READ operation when 
appropriately addressed. 

Note also that the output latch is cleared when the port 
enters the input mode. The output latch cannot be loaded 
by writing to the port if the port is in the input mode. The 
result is that each time a port mode is changed from input 
to output, the output pins will go low. When the 8155/56 is 
RESET, the output latches are all cleared and all 3 ports 
enter the input mode. 

When in the ALT 1 or ALT 2 modes, the bits of PORT C are 
structured like the diagram above in the simple input or 
output mode, respectively. 

Reading from an input port with nothing connected to the 
pins will provide unpredictable results. 



TABLE 1. TABLE OF PORT CONTROL ASSIGNMENT. 



Pin 


ALT1 


ALT 2 


ALT 3 


ALT 4 


PCO 


Input Port 


Output Port 


A INTR (Port A Interrupt) 


A INTR (Port A Interrupt) 


PC1 


Input Port 


Output Port 


A BFJPort A Buffer Full) 


A BF (Port A Buffer Full) 


PC2 


Input Port 


Output Port 


A STB (Port A Strobe) 


A STB (Port A Strobe) 


PC3 


Input Port 


Output Port 


Output Port 


B INTR (Port B Interrupt) 


PC4 


Input Port 


Output Port 


Output Port 


B BF (Port B Buffer Full) 


PC5 


Input Port 


Output Port 


Output Port 


B STB (Port B Strobe) 



The set and reset of I NTR and BF with respect to STB, WR and RD timing is shown in Figure 8. 
To summarize, the registers' assignments are: 



Address 


Pinouts 


Functions 


No. of Bits 


XXXXXOOO 
XXXXX001 
XXXXX010 
XXXXX011 


Internal 

PAO-7 
PBO-7 
PCO-5 


Command/Status Register 
General Purpose I/O Port 
General Purpose I/O Port 
General Purpose I/O Port or 
Control Lines 


8 
8 
8 
6 
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TIMER SECTION 

The timer is a 14-bit down counter that counts the 'timer 
input' pulses and provides either a square wave or pulse 
when terminal count (TO is reached. 

The timer has the I/O address XXXXX1 00 for the low order 
byte of the register and the I/O address XXXXX101 for the 
high order byte of the register. 

To program the timer, the COUNT LENGTH REG is 
loaded first, one byte at a time, by selecting the timer 
addresses. Bits 0-13 will specify the length of the next 
count and bits 14-15 will specify the timer output mode. 
The value loaded into the count length register can have 
any value from 2h through 3FFFh in Bits 0-13. 

There are four modes to choose from: 

0. Puts out low during second half of count. 

1. Square wave 

2. Single pulse upon TC being reached 

3. Repetitive single pulse everytime TC is readied and 
automatic reload of counter upon TC being reached, until 
instructed to stop by a new command loaded into C/S. 

Bits 6-7 of Command/Status Register Contents are used 
to start and stop the counter. There are four commands to 
choose from: 

Note: See the further description on Command/Status 
Register. 



C/S7 C/S6 



NOP — Do not affect counter operation. 

STOP — NOP if timer has not started; stop 
counting if the timer is running. 

STOP AFTER TC — Stop immediately after 
present TC is reached (NOP if timer has not 
started) 

START — Load mode and CNT length and 
start immediately after loading (if timer is 
not presently running). If timer is running, 
start the new mode and CNT length 
immediately after present TC is reached. 













M 2 


M 1 


T13 


T12 


Tn 


Tio 


T 9 


T 8 






II 






I i 
riMER MODE MSB OF CNT LENGTH 






T 7 


T 6 


T 5 


T 4 


T 3 


T 2 


Ti 


To 












1 
LSB OF CNT LENGTH 





FIGURE 4. TIMER FORMAT 



M2 Ml defines the timer mode as follows: 



M2 Ml^ 









1 



1 

1 1 



Puts out low during second half of 
count. 

Square wave, i.e., the period of the 
square wave equals the count 
length programmed with auto- 
matic reload at terminal count. 

Single pulse upon TC being 

reached. 

Automatic reload, i.e., single pulse 

everytime TC is reached. 



Note: In case of an asymmetric count, i.e. 9, larger half of 
the count will be high, the larger count will stay active as 
shown in Figure 5. 



1_J 



Note: 5 and 4 refer to the number of clock cycles in that 
time period. 

FIGURE 5. ASYMMETRIC COUNT. 



The counter in the 8155 is not initialized to any particular 
mode or count when hardware RESET occurs, but RESET 
does stop the counting. Therefore, counting cannot begin 
following RESET until a START command is issued via the 
C/S register. 
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8155/8156 



ABSOLUTE MAXIMUM RATINGS* 



Temperature Under Bias 0°Cto+70°C 

Storage Temperature -65°Cto+150°C 

Voltage on Any Pin 

With Respect to Ground -0.3Vto+7V 

Power Dissipation 1.5W 



*COMMENT: Stresses above those listed under "Absolute 
Maximum Ratings" may cause permanent damage to the 
device. This is a stress rating only and functional opera- 
tion of the device at these or any other conditions above 
those indicated in the operational sections of this specifi- 
cation is not implied. Exposure to absolute maximum 
rating conditions for extended periods may affect device 
reliability. 



D.C. CHARACTERISTICS (T A = o°c to 70°c ; v cc = 5V ± 5%) 



SYMBOL 


PARAMETER 


MIN. 


MAX. 


UNITS 


TEST CONDITIONS 


V|L 


Input Low Voltage 


-0.5 


0.8 


V 




V|H 


Input High Voltage 


2.0 


V cc +0.5 


V 




Vol 


Output Low Voltage 




0.45 


V 


IrjL = 2mA 


V H 


Output High Voltage 


2.4 




V 


Iqh = -400/xA 


l|L 


Input Leakage 




±10 


MA 


Vin = V cc to 0V 


Ilo 


Output Leakage Current 




±10 


ma 


0.45V <V 0U T <V C c 


'cc 


Vcc Supply Current 




180 


mA 




Iil(CE) 


Chip Enable Leakage 
8155 
8156 




+100 
-100 


juA 

!JA 


V| N = V C c to 0V 
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8155/8156 



A.C. CHARACTERISTICS (t a = o°Cto 70°C; v cc = 


5V ± 5%) 








SYMBOL 


PARAMETER 


MIN. 


MAX. 


UNITS 


TEST CONDITIONS 


tAL 


Address to Latch Set Up Time 


50 




ns 




tLA 


Address Hold Time after Latch 


80 




ns 




tLC 


Latch to READ/WRITE Control 


100 




ns 




tRD 


Valid Data Out Delay from READ Control 




170 


ns 




tAD 


Address Stable to Data Out Valid 




400 


ns 




tLL 


Latch Enable Width 


100 




ns 




*RDF 


Data Bus Float After READ 





100 


ns 




tCL 


READ/WRITE Control to Latch Enable 


20 




ns 




tec 


READ/WRITE Control Width 


250 




ns 




l DW 


Data In to WR ITE Set Up Time 


150 




ns 




*WD 


Data In Hold Time After WRITE 







ns 




tRV 


Recovery Time Between Controls 


300 




ns 




t W P 


WRITE to Port Output 




400 


ns 




tPR 


Port Input Setup Time 


70 




ns 




tRP 


Port Input Hold Time 


50 




ns 


1 50 pF Load 


tSBF 


Strobe to Buffer Full 




400 


ns 




tss 


Strobe Width 


200 




ns 




*RBE 


READ to Buffer Empty 




400 


ns 




tsi 


Strobe to I NTR On 




400 


ns 




*RDI 


READ to I NTR Off 




400 


ns 




tpss 


Port Setup Time to Strobe Strobe 


50 




ns 




tPHS 


Port Hold Time After Strobe 


120 




ns 




tSBE 


Strobe to Buffer Empty 




400 


ns 




*WBF 


WRITE to Buffer Full 




400 


ns 




l WI 


WRITE to INTROff 




400 


ns 




tTL 


TIMER-IN to TIMER-OUT Low 




400 


ns 




tTH 


TIMER-IN to TIMER-OUT High 




400 


ns 




*RDE 


Data Bus Enable from READ Control 


10 




ns 





Note: For Timer Input Specification, see Figure 10. 
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CE (8155) 

OR 
CE (8156) 



X 

X 



\ 



/ 



X 



X 



8155/8156 



A. READ CYCLE 



\ 



X 



7 



L 



X 



> 



■ t >c DaTAvAu ° i — C 






V ■* <RD- 



£ 



B. WRITE CYCLE 



X 



X 



/ X 



X 



7 



Z 



X 



a 



DATA VALID 



£ 



J 



X f 



FIGURE 7. 8155/8156 READ/WRITE TIMING DIAGRAMS. 
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8155/8156 



A. STROBED INPUT MODE 




INPUT DATA 
FROM PORT 



B. STROBED OUTPUT MODE 



OUTPUT DATA 
TO PORT 




FIGURE 8. STROBED I/O TIMING. 
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8155/8156 



A. BASIC INPUT MODE 



X 



^k / 



X 



riimix 



B. BASIC OUTPUT MODE 



\ / 



•DATA BUS TIMING IS SHOWN IN FIGURE 7. 



y, y izzz 



x 



FIGURE 9. BASIC I/O TIMING WAVEFORM. 



LOAD COUNTER FROM CLR 
2 I 




TIMER OUT 
(SQUARE WAVE) 



NOTE 1: THE TIMER OUTPUT IS PERIODIC IF IN AN AUTOMATIC 
RELOAD MODE (M] MODE BIT= 1) 



COUNTDOWN FROM 5 TO 1 



'CYC 


320 nsec 


MIN. 


t r AND t f 


30 nsec 


MAX. 


tl 


80 nsec 


MIN. 


t2 


120 nsec 


MIN. 


t TL ANDt T H 


400 nsec 


MAX. 



FIGURE 10. TIMER OUTPUT WAVEFORM. 
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MCS-48 



8243 
INPUT/OUTPUT EXPANDER 



□ Low Cost 

a Simple Interface to MCS-48™ Micro- 
computers 
a Four 4-Bit I/O Ports 

□ AND and OR Directly to Ports 



□ 24-Pin DIP 

□ Single 5V Supply 
n High Output Drive 

□ Direct Extension of Resident 8048 I/O 
Ports 



The Intel® 8243 is an input/output expander designed specifically to provide a low cost means of I/O expansion for the 
MCS-48™ family of single chip microcomputers. Fabricated in 5 volts NMOS, the 8243 combines low cost, single supply 
voltage and high drive current capability. 

The 8243 consists of four 4-bit bidirectional static I/O ports and one 4-bit port which serves as an interface to the MCS-48 
microcomputers. The 4-bit interface requires that only 4 I/O lines of the 8048 be used for I/O expansion, and also allows 
multiple 8243's to be added to the same bus. 

The I/O ports of the 8243 serve as a direct extension of the resident I/O facilities of the MCS-48 microcomputers and are 
accessed by their own MOV, ANL, and ORL instructions. 



PIN CONFIGURATION 



BLOCK DIAGRAM 



P50 C 


1 


y 24 


3 V CC 


P40 C 


2 


23 


DP51 


P41 L" 


3 


22 


DP52 


P42 C 


4 


21 


DP53 


P43C 


5 


20 


DP60 


csC 
progC 


6 19 
8243 

7 18 


HP61 
I]P62 


P23C 


8 


17 


I]P63 


P22C 


9 


16 


HP73 


P21C 


10 


15 


HP72 


P20E 


11 


14 


HP71 


GNDC 


12 


13 


DP70 



«x> 



r/ D 



O 



=7^> 



a 



p 



1 



:> 



£ 



iz 



RESET 
CIRCUIT 



P 



4 > PORT 5 



a 



UP 



> 



4 > PORT 6 



P 



o 



4 > PORT 7 



■a 
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8243 



PIN DESCRIPTION 



Symbol 



Pin No. 



Function 



PROG 



CS 



P20-P23 



GND 



P40-P43 


2-5 


P50-P53 


1,23-21 


P60-P63 


20-17 


P70-P73 


13-16 



'CC 



7 Clock Input. A high to low 

transistion on PROG signifies 
that address and control are 
available on P20-P23, and a low 
to high transition signifies that 
data is available on P20-23. 

6 Chip Select Input. A high on CS 

inhibits any changeof output or 
internal status. 

11-8 Four-bit bidirectional port con- 
tains the address and control 
bits on a high to low transition 
of PROG. During a low to high 
transition contains the data for 
a selected output port if a write 
operation, or the data from a 
selected port before the low to 
high transition if a read oper- 
ation. 

12 0V supply. 

Four-bit bidirectional I/O ports. 
May be programmed to be input 
(during read), low impedance 
latched output (after write) or a 
tri-state (after read). Data on 
pins P20-23 may be directly 
written. ANDed or ORed with 
previous data. 

24 +5V supply. 



FUNCTIONAL DESCRIPTION 

General Operation 

The 8243 contains four 4-bit I/O ports which serve as an 
extension of the on-chip I/O and are addressed as ports 4- 
7. The following operations may be performed on these 
ports: 

• Transfer Accumulator to Port. 

• Transfer Port to Accumulator. 

• AND Accumulator to Port. 

• OR Accumulator to Port. 

All communication between the 8048 and the 8243 occurs 
over Port 2 (P20-P23) with timing provided by an output 
pulse on the PROG pin of the processor. Each transfer 
consists of two 4-bit nibbles: 

The first containing the "op code" and port address and 
the second containing the actual 4-bits of data. 



A high to low transition of the PROG line indicates that 
address is present while a low to high transition indicates 
the presence of data. Additional 8243's may be added to 
the 4-bit bus and chip selected using additional output 
lines from the 8048/8748/8035. 

Power On Initialization 

Initial application of power to the device forces 
input/output ports 4, 5, 6, and 7tothetri-stateand port 2to 
the input mode. The PROG pin may be either high or low 
when power is applied. The first high to low transition of 
PROG causes device to exit power on mode. The power on 
sequence is initiated if Vqq drops below 1V. 

P21 P20 Address Code P23 P22 Instruction Code 



Port 4 
Port 5 
Port 6 
Port 7 



Read 
Write 
ORLD 
ANLD 



Write Modes 

The device has three write modes. MOVD Pi, A directly 
writes new data into the selected port and old data is lost. 
ORLD Pi, A takes new data, OR's it with the old data and 
then writes it to the port. ANLD Pi.AtakesnewdataAND's 
it with the old data and then writes it to the port. Operation 
code and port address are latched from the input port 2 on 
the high to low transition of the PROG pin. On the low to 
high transition of PROG data on port 2 is transferred to the 
logic block of the specified output port. 

After the logic manipulation is performed, the data is 
latched and outputed. The old data remains latched until 
new valid outputs are entered. 

Read Mode 

The device has one read mode. The operation code and 
port address are latched from the input port 2 on the high 
to low transition of the PROG pin. As soon as the read 
operation and port address are decoded, the appropriate 
outputs are tri-stated, and the input buffers switched on. 
The read operation is terminated by a low to high 
transition of the PROG pin. The port (4, 5, 6 or 7) that was 
selected is switched to the tri-stated mode while port 2 is 
returned to the input mode. 

Normally, a port will be in an output (write mode) or input 
(read mode). If modes are changed during operation, the 
first read following a write should be ignored; all following 
reads are valid. This is to allow the external driver on the 
port to settle after the first read instruction removes the 
low impedance drive from the 8243 output. A read of any 
port will leave that port in a high impedance state. 



Note: The 8243 does not have the same quasi-bidirectional port structure as P1/P2of the 8048. When a "1" is written to P4-7 
of the 8243 it is a "hard 1" (low impedance to +5V) which cannot be pulled low by an external device. All 4 bits of any port 
can be switched from output mode to input mode by executing a dummy read which leaves the port in a high impedance (no 
pullup or pulldown) state. 
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8243 



ABSOLUTE MAXIMUM RATINGS' 



Ambient Temperature Under Bias C to 70 C 

Storage Temperature -65°C to +150°C 

Voltage on Any Pin 

With Respect to Ground -0.5V to +7V 

Power Dissipation 1 Watt 



*COMMENT: Stresses above those listed under "Absolute 
Maximum Ratings" may cause permanent damage to the 
device. This is a stress rating only and functional opera- 
tion of the device at these or any other conditions above 
those indicated in the operational sections of this specifi- 
cation is not implied. Exposure to absolute maximum 
rating conditions for extended periods may affect device 
reliability. 



D.C. AND OPERATING CHARACTERISTICS 

T A = 0°Cto 70° C, V cc = 5V ±10% 



Symbol 


Parameter 


Min. 


Typ. 


Max. 


Units 


Test Conditions 


V|L 


Input Low Voltage 


-0.5 




0.8 


V 




V| H 


Input High Voltage 


2.0 




Vcc+0.5 


V 




VoL1 


Output Low Voltage Ports 4-7 






0.45 


V 


Iol = 5 mA* 


V OL2 


Output Low Voltage Port 7 






1 


V 


Iql = 20 mA 


Vom 


Output High Voltage Ports 4-7 


2.4 






V 


I O h=240mA 


1 IL1 


Input Leakage Ports 4-7 


-10 




20 


juA 


V in =V cc to0V 


1 IL2 


Input Leakage Port 2, CS, PROG 


-10 




10 


jkA 


V in =V cc to0V 


V OL3 


Output Low Voltage Port 2 






.45 


V 


l L =0 - 6 mA 


■cc 


Vcc Supply Current 




10 


20 


mA 




VOH2 


Output Voltage Port 2 


2.4 








l O H=100j"A 


lOL 


Sum of all Iql f rom 16 Outputs 






100 


mA 


5 mA Each Pin 



*See following graph for additional sink current capability. 

A.C. CHARACTERISTICS 

T A = 0°C to 70°C, V cc = 5V ± 10% 



Symbol 


Parameter 


Min. 


Max. 


Units 


Test Conditions 


tA 


Code Valid Before PROG 


100 




ns 


80 pF Load 


t B 


Code Valid After PROG 


60 




ns 


20 pF Load 


tc 


Data Valid Before PROG 


200 




ns 


80 pF Load 


t D 


Data Valid After PROG 


20 




ns 


20 pF Load 


t H 


Floating After PROG 





150 


ns 


20 pF Load 


t« 


PROG Negative Pulse Width 


700 




ns 




tcs 


CS Valid Before/After PROG 


50 




ns 




tpo 


Ports 4-7 Valid After PROG 




700 


ns 


100 pF Load 


tLP1 


Ports 4-7 Valid Before/After PROG 


100 




ns 




tACC 


Port 2 Valid After PROG 




650 


ns 


80 pF Load 
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WAVEFORMS 



"V v v v 

jl INSTRUCTION V FLOAT V DATA j[ 



\X> OUTPUT \X 

A ™° A 



PREVIOUS OUTPUT VALID 



t|P 



•*-t 

V 



INPUT VALID 



■* l PO *~ 



X 



OUTPUT 
VALID 
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8243 



125 

< 
E 

- 100 

_o 

H 75 



DC 

DC 
D 
O 

z 

-J 
< 
I- 

o 



50 



25 



GUARANTEED WORST CASE 
CURRENT SINKING 
CAPABILITIES OF ANY I/O 
PORT PIN vs. TOTAL SINK 
CURRENT OF ALL PINS 



1 



10 11 12 13 



MAXIMUM SINK CURRENT ON ANY PIN@.4(I 0L ) 
MAXIMUM l 0L W0RST CASE PIN (mA) 



Sink Capability 

The 8243 can sink 5 mA @ .4V on each of its 16 I/O lines 
simultaneously. If, however, all linesarenotsinking simul- 
taneously or all lines are not fully loaded, the drive capa- 
bility of any individual line increases as is shown by the 
accompanying curve. 

For example, if only 5 of the 16 lines are to sink current at 
one time, the curve shows that each of those 5 lines is 
capable of sinking 10 mA @ .4V (if any lines are to sink 
10 mA the total Iol must not exceed 50 mA or five 10 mA 
loads). 

Example: How many pins can drive 5 TTL loads (1.6 mA) 
assuming remaining pins are unloaded? 

Iol = 5 x 1.6 mA = 8 mA 
eloL = 70 mA from curve 
# pins = 70 mA ^ 8 mA/pin = 8.75 = 8 

I n this case, 8 lines can sink 8 mA for a total of 64 
mA. This leaves 6 mA sink current capability 
which can be divided in any way among the 
remaining 8 I/O lines of the 8243. 



Example: This example shows how the use of the 20 mA 
sink capability of Port 7 affects the sinking 
capability of the other I/O lines. 

An 8243 will drive the following loads 
simultaneously. 

2 loads — 20 mA @ 1V (port 7 only) 

8 loads — 5 mA @ .4V 

6 loads — 3.2 mA @ .4V 

Is this within the specified limits? 

eloL = (2 x 20) + (8 x 5) + (6 x 3.2) = 99.2 mA from 
the curve: for Iol = 5 mA, eloL = 100 mA since 
99.2 mA< 100 mA the loads are within specified 
limits. 

Although the 20 mA @ 1V loads are used in 
calculating eloL, it is the largest current 
required @ .4V which determines the maximum 
allowable eloL- 



Note: A 10 to 50Kft pullup resistor to +5V should be added to 8243 outputs when driving to 5V CMOS directly. 
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EXPANDER INTERFACE 



OO 1 



PROG 

8048 

P20-P23 



c 



I TEST 
I INPUTS 



c 



s 



■EL 









c 



OUTPUT EXPANDER TIMING 



\ 



/ 



^zx 



ADDRESS (4-BITS) DATA (4-BITS) 



10 ADDRESS 



CO 



PROG P20-3 



75 






PROG P20-3 



7T 






PROG P20-3 






PROG P20-3 



<3> 

<X> 



USING MULTIPLE 8243's 
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Chapter 7 
COMPATIBLE MCS-80™ COMPONENTS 




COMPATIBLE MCS-80™ COMPONENTS 



8308 8192 Bit Static MOS ROM 7-1 

2316E 16,384 Bit Static MOS ROM 7-5 

8708 8192 1Kx8 EPROM 7-9 

2716 16K UV Erasable PROM 7-13 

8101A-4 1024 Bit Static MOS RAM With 

Separate I/O 7-17 

8111A-4 1024 Bit Static MOS RAM With 

Common I/O 7-21 

5101 1024 Bit Static CMOS RAM 7-25 

8212 Eight-Bit Input/Output Port 7-29 

8255A Programmable Peripheral Interface 7-39 

8251 A Programmable Communication Interface ...7-61 

8205 High Speed 1 Out of 8 Binary Decoder 7-77 

8214 Priority Interrupt Control Unit 7-83 

8216/8226 4-Bit Parallel Bi-Directional Bus Driver 7-87 

8253,8253-5 Programmable Interval Timer 7-93 

8259 Programmable Interrupt Controller 7-105 

8279,8279-5 Programmable Peripheral Interface 7-121 

8278 Programmable Keyboard Interface 7-133 

8041/8741 Universal Peripheral Interface 

8-Bit Microcomputers 7-143 




8308 
8192 BIT STATIC MOS READ ONLY MEMORY 

Organization — 1024 Words x 8 Bits 



Fast Access — 450 ns 

Directly Compatible with 8080 CPU at 
Maximum Processor Speed 

Two Chip Select Inputs for Easy 
Memory Expansion 



Directly TTL Compatible — All Inputs 
and Outputs 

Three State Output — OR-Tie 
Capability 

Fully Decoded 

Standard Power Supplies +12V DC, 5V 
DC 



The Intel® 8308 is an 8,192 bit static MOS mask programmable Read Only Memory organized as 1024 words by 8-bits. This 
ROM is designed for 8080 microcomputer system applications where high performance, large bit storage, and simple inter- 
facing are important design objectives. The inputs and outputs are fully TTL compatible. 

A pin for pin compatible electrically programmed erasable ROM, the Intel® 8708, is available for system development and 
small quantity production use. 

Two Chip Selects are provided — CSi which is negative true, and CS2/CS2 which may be programmed either negative or 
positive true at the mask level. 

The 8308 read only memory is fabricated with N-channel silicon gate technology. This technology provides the designer with 
high performance, easy-to-use MOS circuits. 



PIN CONFIGURATION 




BLOCK DIAGRAM 

DATA OUT 1 DATA OUT 8 

t 1 



CS V 



OUTPUT 
BUFFERS 



8192 BIT 

ROM MATRIX 

(1024X8) 



INPUT 
BUFFERS 



t I" 



A 9 



PIN NAMES 



Ao- A 9 


ADDRESS INPUTS 


O r 8 


DATA OUTPUTS 


CSl cs 2 


CHIP SELECT INPUTS 



8308 



ABSOLUTE MAXIMUM RATINGS* 

Ambient Temperature Under Bias -25°C to +85°C 

Storage Temperature -65°C to +150°C 

Voltage On Any Pin With Respect 

To V BB -0.3V to 20V 

Power Dissipation 1.0 Watt 



"COMMENT 

Stresses above those listed under "Absolute Maximum Ratings" may 
cause permanent damage to the device. This is a stress rating only 
and functional operation of the device at these or any other condi- 
tions above those indicated in the operational sections of this speci- 
fication is not implied. Exposure to absolute maximum rating condi- 
tions for extended periods may affect device reliability. 



PROGRAMMING 

The programming specifications are described in the PROM/ROM Programming Instructions on page 6-74. 

D.C. AND OPERATING CHARACTERISTICS 

T A = 0°C to +70°C, V cc = 5V ±5%; V DD = 12V ±5%, V BB = -5V ±5%, V ss = 0V Unless Otherwise Specified. 



Symbol 


Parameter 


Limits 


Unit 


Test Conditions 


Min. 


Typ.Ml 


Max. 


Ili 


Input Load Current 

(All Input Pins Except CS^ ) 






±10 


AiA 


V, N = to 5.25V 


•lcl 


Input Load Current on CSt 






-1.6 


mA 


V| N = 0.45V 


■ lpc 


Input Peak Load Current on CS^ 






-4 


mA 


V| N = 0.8V to 3.3V 


■lkc 


Input Leakage Current on CSt 






10 


HA 


V| N = 3.3V to 5.25V 


Ilo 


Output Leakage Current 






10 


KA 


Chip Deselected 


V,L 


Input "Low" Voltage 


Vss-1 




0.8V 


V 




V,H 


Input "High" Voltage 


3.3 




Vcc+1-0 


V 




Vol 


Output "Low" Voltage 






0.45 


V 


l 0L = 2mA 


V OH1 


Output "High" Voltage 


2.4 






V 


Iqh = -4mA 


V OH2 


Output "High" Voltage 


3.7 






V 


Iqh =-1mA 


•cc 


Power Supply Current Vcc 




10 


15 


mA 




>DD 


Power Supply Current Vprj 




32 


60 


mA 




■bb 


Power Supply Current V BB 




10mA 


1 


mA 




Pd 


Power Dissipation 




460 


840 


mW 





NOTE 1: Typical values for T A = 25° C and nominal supply voltage 



D.C. OUTPUT CHARACTERISTICS 



D.C. OUTPUT CHARACTERISTICS 
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H.C. CHARACTERISTICS 

f A = 0°C to +70°C, V cc = +5V ±5%; V DD = +12V ±5%, V BB = -5V ±5%, V ss = 0V, Unless Otherwise Specified. 



Symbol 


Parameter 


Limitst 2 ! 


Unit 


Min. 


Typ. 


Max. 


Ucc 


Address to Output Delay Time 




200 


450 


ns 


tcoi 


Chip Select 1 to Output Delay Time 




85 


160 


ns 


tC02 


Chip Select 2 to Output Delay Time 




125 


220 


ns 


tDF 


Chip Deselect to Output Data Float Time 




125 


220 


ns 



JOTE 2: Refer to conditions, of Test for A.C. Characteristics. Add 50 nanoseconds (worst case) to specified values at 
Vqh = 3.7V @ Iqh = -1mA, C|_ = 100pF. 



CONDITIONS OF TEST FOR 
A.C. CHARACTERISTICS 

Output Load 1 TTL Gate, and C LO ad = 100pF 

Input Pulse Levels 65V to 3.3V 

Input Pulse Rise and Fall Times 20 nsec 

Timing Measurement Reference Level 
2.4V V, H , V 0H ; 0.8V V, L , V 0L 



CAPACITANCE T A = 25°C, f = 1 MHz, V BB = -5V, V DD , 
Vcc ar| d all other pins tied to Vss- 



Symbol 


Test 


Limits 


Typ. 


Max. 


C IN 


Input Capacitance 





6pF 


Cqut 


Output Capacitance 


12pF 




cs 2 /cs 2 



: :-.-: : x : : : : : : : ^x-x:x-^:::^:0;:;;:;::T!^x^: 




DATAO r 7 




liliit-^Eil- 
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TYPICAL CHARACTERISTICS (Nominal supply voltages unless otherwise noted.) 



'dd vs. temperature 
(normalized) 



A OUTPUT CAPACITANCE 
VS. A OUTPUT DELAY 
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10 20 30 40 50 60 70 80 90 
AMBIENT TEMPERATURE T A (°C) 



-50 +50 

A CAPACITANCE (pFI 



CSt input 
CHARACTERISTICS 



T ACC VS. TEMPERATURE 
(NORMALIZED) 
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231 6E 
16K(2Kx8)ROM 



q Fast Access Time— 450 ns Max. 

° Single +5V±10% Power Supply 

■ Intel MCS 80 and 85 Compatible 

a Three Programmable Chip 
Selects for Simple Memory 
Expansion and System Interface 



a EPROM/ROM Pin Compatible for 
Cost-Effective System 
Development 

■» Completly Static Operation 

o Inputs and Outputs TTL 
Compatible 

a Three-State Output for Direct 
Bus Interface 



The Intel® 2316E is a 16,384-bit static, N-channel MOS read only memory (ROM) organized as 2048 words by 8 bits. Its 
high bit density is ideal for large, non-volatile data storage applications such as program storage. The three-state outputs and 
TTL input/output levels allow for direct interface with common system bus structures. The 2316E single +5V power supply 
and 450 ns access time are both ideal for usage with high performance microcomputers such as the Intel MCS™ -80 and 
MCS™ -85 devices. 

A cost-effective system development program may be implemented by using the pin compatible Intel 2716 16K UV EPROM 
for prototyping and the lower cost 2616 PROM and 2316E ROM for production. The 2716 is fully compatible to the 2316E 
in all respects. The three 2316E programmable chip selects may be defined by the user and are fixed during the masking pro- 
cess. To simplify the conversion from 2716 prototyping to 2316E production, it is recommended that the 2316E program- 
mable chip select logic levels be defined the same as that shown in the below data sheet pin configuration. This pin configura- 
tion and these chip select logic levels are the same as the 2716. 



PIN CONFIGURATION 



A 7 £ 




V> ^ 24 


3 v C c 


A6 C 


2 


23 


3 A 8 


A5C 


3 


22 


3 Ag 


A4C 


4 


21 


3 CS3 


A3 C 


5 


20 


3 csi 


A 2 \Z 


6 


19 


3 A10 


AlC 




18 


3 CS 2 


AoC 


8 


17 


3 D 7 


00 C 


9 


16 


3 D 6 


DiC 


10 


15 


3 D 5 


D2C 


11 


14 


3 Di 


gndC 


12 


13 


3 o 3 


PIN NAMES 


A0-A10 


ADDRESS INPUTS 


D7-D0 


DATA OUTPUTS 


CS1-CS3 


CHIP SELECT INPUTS 



BLOCK DIAGRAM 



Do D1 D2 D3 D4 D5 D6 O7 



A10 ■ 
Ag ■ 
A 8 ■ 
A 7 • 
A6 ' 
A5 ' 



OUTPUT BUFFERS 



' DECODER 1 OF 16 » 8 



u 



t t t t t t t I 



16. 384 BIT 
CELL MATRIX 



Li_l 



CHIP 
SELECT 
PROG. 



.t t t. 



CHIP 

SELECT 

INPUT 

BUFFERS 



2316E 



ABSOLUTE MAXIMUM RATINGS* 

Ambient Temperature Under Bias -10°Cto 80°C 

Storage Temperature -65°C to +150°C 

Voltage On Any Pin With Respect 

to Ground -0.5V to +7V 

Power Dissipation 1.0 Watt 



'COMMENT: Stresses above those listed under "Absolute Maxi- 
mum Ratings" may cause permanent damage to the device. This is a 
stress rating only and functional operation of the device at these or 
at any other conditions above those indicated in the operational 
sections of this specification is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect device 
reliability. 



D.C. AND OPERATING CHARACTERISTICS 

T A = 0°C to +70°C, V cc = 5V ±10%, unless otherwise specified. 



SYMBOL 


PARAMETER 


LIMITS 


UNIT 


TEST CONDITIONS 


MIN. 


TYP.< 1 » 


MAX. 


I LI 


Input Load Current 
(All Input Pins) 






10 


jtiA 


V| N = to 5.25V 


'loh 


Output Leakage Current 






10 


/xA 


Chip Deselected, Vqut = 4 - 0v 


• lol 


Output Leakage Current 






-20 


juA 


Chip Deselected, Vqut = °- 4v 


'cc 


Power Supply Current 




70 


120 


mA 


All Inputs 5.25V Data Out Open 


V|L 


Input "Low" Voltage 


-0.5 




0.8 


V 




V| H 


Input "High" Voltage 


2.2 




Vcc+1-0V 


V 




Vol 


Output "Low" Voltage 






0.4 


V 


I l= 2.1 mA 


Voh 


Output "High" Voltage 


2.4 






V 


Ioh=-400/xA 


NOTE: 1 . Typical values for T/\ = 25° C and nominal supply voltage. 



A.C. CHARACTERISTICS 

T A = 0°C to +70°C, V cc = +5V ±10%, unless otherwise specified. 



SYMBOL 


PARAMETER 


LIMITS 


UNIT 


MIN. 


MAX. 


tA 


Address to Output Delay Time 




450 


ns 


tco 


Chip Select to Output Enable Delay Time 




120 


ns 


tDF 


Chip Deselect to Output Data Float Delay Time 


10 


100 


ns 





CONDITIONS OF TEST FOR 
A.C. CHARACTERISTICS 

Output Load 1 TTLGate and C L = 100 pF 

Input Pulse Levels 0.8 to 2.4V 

Input Pulse Rise and Fall Times (10% to 90%) 20 ns 

Timing Measurement Reference Level 

Input 1V and 2.2V 

Output 0.8V and 2.0V 



CAPACITANCE® T A = 25°C, f = 1 MHz 



SYMBOL TEST 


LIMITS 


TYP. 


MAX. 


C|n All Pins Except Pin Under 
Test Tied to AC Ground 


5pF 


10 pF 


Cout All Pins Except Pin Under 
Test Tied to AC Ground 


10 pF 


15pF 



NOTE: 2. This parameter is periodically sampled and is not 100% 
tested. 
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.C. Waveforms 



231 6E 




OUTPUT VALID 



////// OUTPUT HIGH IMPEDANCE //// 

wmmmA 



ypical System Application (8K x 8 ROM Memory) 



ADDRESS BUS 



CONTROL BUS 



A12 /' / All 



T\ 



CHIP 

SELECT 

DECODER 

(INTEL 

8205) 



►O CS2 
CS3 



►O CS2 
CS3 



\7 



►O CS2 
CS3 




8708 
8192 BIT ERASABLE AND ELECTRICALLY 
REPROGRAMMABLE READ ONLY MEMORY 



o 8708 1024x8 Organization 



H Fast Programming — 
Typ. 100 sec. For All 8K Bits 

a Low Power During Programming 
B Access Time — 450 ns 
& Standard Power Supplies — 
+12V, ±5V 



Static— No Clocks Required 

Inputs and Outputs TTL 
Compatible During Both Read 
and Program Modes 

Three-State Output— OR-Tie 
Capability 



The Intel® 8708 is a high speed 8192 bit erasable and electrically reprogrammable ROM (EPR0M) ideally suited where 
fast turn around and pattern experimentation are important requirements. 

The 8708 is packaged in a 24 pin dual-in-line package with transparent lid. The transparent lid allows the user to expose the 
chip to ultraviolet light to erase the bit pattern. A new pattern can then be written into the device. 

A pin for pin mask programmed ROM, the Intel® 8308, is available for large volume production runs of systems initially 
using the 8708. 

The 8708 is fabricated with the time proven N-channel silicon gate technology. 



PIN CONFIGURATION 



A7C 




<^f— 


24 


I]Vcc 


AeC 


2 




23 


:«. 


A,C 


3 




22 


Da, 


A.C 


4 




21 


D^B 


A3C 


5 




20 


^ CS/WE 


A>C 


6 


8708 


19 


D*D 


A,C 


7 




18 


^ PROGRAM 


AoC 


8 




17 


I] B 


o,C 


9 




16 


I] 0, 


o,C 


10 




15 


U°e 


O.C 


11 




14 


Do 5 


*c 


12 




13 


3°. 



PIN NAMES 



A0-A9 


ADDRESS INPUTS 


o r o 8 


DATA OUTPUTS 


CS/WE 


CHIP SELECT /WRITE ENABLE INPUT 



BLOCK DIAGRAM 



















1 












1 
















"~ 1 


CS'W 




CHIPSELECT 
LOGIC 




OUTPUT BUFFERS 
















Y 
DECODER 


Y GATING 
























X 
DECODER 


64 X 128 
ROM ARRAY 






ADDRESS-^ 
INPUTS 
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8708 

PROGRAMMING 

The programming specifications are identical to those of the 2708. 
page 6-74). 

ABSOLUTE MAXIMUM RATINGS* 

Temperature Under Bias -25°Cto +85°C 

Storage Temperature -65°C to +125°C 

V DD With Respect to V BB +20V to -0.3V 

V cc and Vss With Respect to V BB +15V to -0.3V 

All Input or Output Voltages With 

Respect to V BB During Read +15Vto-0.3V 

CS/WE Input With Respect to V BB 

During Programming +20V to -0.3V 

Program Input With Respect to V BB +35V to -0 3V 

Power Dissipation 1.5W 



(See ROM and PROM Programming Instructions, 



*COMMENT: Stresses above those listed under "Absolute 
Maximum Ratings" may cause permanent damage to the 
device. This is a stress rating only and functional opera- 
tion of the device at these or any other conditions above 
those indicated in the operational sections of this specifi- 
cation is not implied. Exposure to absolute maximum 
rating conditions for extended periods may affect device 
reliability. 



READ OPERATION 

D.C. AND OPERATING CHARACTERISTICS 

T A = 0°C to 70°C, V cc = +5V ±5%, V DD = +12V ±5%, V BB = -5V ±5%, V ss = 0V, Unless Otherwise Noted. 



Symbol 


Parameter 


Min. 


Typ.m 


Max. 


Unit 


Conditions 


Ili 


Address and Chip Select Input Sink Current 




1 


10 


MA 


V| N = 5.25 V or V iN = V, L 


"lo 


Output Leakage Current 




1 


10 


fiA 


V UT = 5.25V, CS/WE = 5V 


Idd [2] 


Vqd Supply Current 




50 


65 


mA 


Worst Case Supply Currents: 


lcc [2) 


Vqc Supply Current 




6 


10 


mA 


All Inputs High 


Ibb [2] 


V BB Supply Current 




30 


45 


mA 


CS/WE = 5V; T A = 0°C 


VlL 


Input Low Voltage 


Vss 




0.65 


V 




V| H 


Input High Voltage 


3.0 




V CC +1 


V 




Vol 


Output Low Voltage 


0.45 


V 


I l= 1.6mA 


V OH1 


Output High Voltage 


3.7 


V 


l 0H =_-100/iA 


V OH2 


Output High Voltage 


2.4 


V 


Iqh = -1mA 


Pd 


Power Dissipation 


800 


mW 


T A = 70°C 



NOTES: 1. Typical values are for T A = 25°C and nominal supply voltages. 

2. The total power dissipation of the 8708 is specified at 800 mW. It is not calculable by summing the various currents 
f'DD» 'CO ar> d 'BE}) rnultiplied by their respective voltages since current paths exist between the various power supplies and 
Vss- "l* ne 'DD< 'CC> anc ' 'BB currents should be used to determine power supply capacity only. 

TYPICAL D.C. CHARACTERISTICS 



MAXIMUM JUNCTION TEMPERATURE 
VS. AMBIENT TEMPERATURE 




RANGE OF SUPPLY CURRENTS 
VS. TEMPERATURE 



ALL POSSIBLE OPERATING 
CONDITIONS: 

V cc - 5.25V 

V DD = 12.6 V 

V RR - -5.25V 




OUTPUT SINK CURRENT 
VS. OUTPUT VOLTAGE 



V cc • 4.75V 








T A = 0°C ^ 
T A -25*C S 


\ / 





































80 100 



8708 



A.C. CHARACTERISTICS 

T A = 0°C to 70°C, V cc = +5V ±5%, V DD = +12V ±5%, V BB = -5V ±5%, V ss = 0V, Unless Otherwise Noted. 



Symbol 


Parameter 


Min. 


Typ. 


Max. 


Unit 


T-ACC 


Address to Output Delay 




280 


450 


ns 


tco 


Chip Select to Output Delay 




60 


120 


ns 


t D F 


Chip De-Select to Output Float 







120 


ns 


1-0 H 


Address to Output Hold 









ns 



CAPACITANCE T A =25°c,f 


= 1MF 


Iz 




Symbol 


Parameter 


Typ. 


Max. 


Unit 


Conditions 


C IN 


Input Capacitance 


4 


6 


pF 


V, N =0V 


C OUT 


Output Capacitance 


8 


12 


pF 


V O ut=0V 



Note . This parameter is periodically sampled and not 100% tested. 

A.C. TEST CONDITIONS 

Output Load: 1 TTL gate and C L = 100pF 

Input Rise and Fall Times: <20ns 

Timing Measurement Reference Levels: 0.8V and 2.8V for inputs; 0.8V and 2.4V for outputs 

Input Pulse Levels: 0.65V to 3.0V 

WAVEFORMS 



■DATA OUT INVALIDS 



DATA OUT 
FLOATING: 



ERASURE CHARACTERISTICS 

The erasure characteristics of the 8708 are such that 
erasure begins to occur when exposed to light with 
wavelengths shorter than approximately 4000 Angstroms 
(A). It should be noted that sunlight and certain types of 
fluorescent lamps have wavelengths in the 3000-4000A 
range. Data show that constant exposure to room level 
flourescent lighting could erase the typical 8708 in 
approximately 3 years while it would take approximately 1 
week to cause erasure when exposed to direct sunlight. If 
the 8708 is to be exposed to these types of lighting 
conditions for extended periods of time, opaque labels are 
available from Intel which should be placed over the 8708 
window to prevent unintentional erasure. 



The recommended erasure procedure (see page 3-55) for 
the 8708 is exposure to shortwave ultraviolet light which 
has a wavelength of 2537 Angstroms (A). The integrated 
dose (i.e., UV intensity X exposure time) for erasure 
should be a minimum of 15W-sec/cm2. The erasure time 
with this dosage is approximately 15 to 20 minutes using 
an ultraviolet lamp with a 1 2000uW7cm 2 power rating. The 
8708 should be placed within one inch from the lamp tubes 
during erasure. Some lamps have a filter on their tubes 
and this filter should be removed before erasure. 



7-11 



7-12 



intgl 



2716 
16K (2Kx8) UV ERASABLE PROM 



■ Single +5V Power Supply 

a Simple Programming Requirements 
Single Location Programming 
Programs With One 50ms Pulse 

■ Low Power Dissipation 

525mW Max. Active Power 
132mW Max. Standby Power 



Pin Compatible To Intel 2316E ROM 
Fast Access Time: 450ns Max. 

Inputs and Outputs TTL 
Compatible During Read 
And Program 



The Intel® 2716 is a 16,384-bit ultraviolet erasable and electrically programmable read-only memory (EPROM). The 2716 
operates from a single 5-volt power supply, has a static power down mode, and features fast single address location program- 
ming. It makes designing with EPROMs faster, easier and more economical. For production quantities, the 2716 user can 
convert rapidly to Intel's new pin-for-pin compatible 16K ROM, the 231 6E. 

Since the 450-nsec 2716 operates from a single 5-volt supply, it is ideal for use with the newer high performance +5V micro- 
processors such as Intel's 8085 and 8048. The 2716 is also the first EPROM with a static power down mode which reduces 
the power dissipation without increasing access time. The maximum active power dissipation is 525 mW while the maximum 
standby power dissipation is only 132 mW, a 75% savings. 

The 2716 has the simplest and fastest method yet devised for programming EPROMs — single pulse TTL level programming. 
No need for high voltage pulsing because all programming controls are handled by TTL signals. Now, it is possible to program 
on-board, in the system, in the field. Program any location at any time — either individually, sequentially or at random, with 
the 2716's single address location programming. Total programming time for all 16,384 bits is only 100 seconds. 



PIN CONFIGURATION 



A 7 C 1 
A6C 2 
A5C 3 
A4C 4 
A3C 5 
A2C 6 
A1C 7 
AoC 8 
O C 9 

01 C 10 

02 C H 
GNDC 12 



24 IJVCC 
23 DAB 
22 3A 9 
21 3VPP 
20 3CS 
19 3 A 10 
18 3 PD/PGM 
17 307 
16 30? 
15 305 
14 304 
13 3 03 



PIN NAMES 



A0-A10 


ADDRESSES 


PD/PGM 


POWER DOWN/PROGRAM 


CS 


CHIP SELECT 


O0-O7 


OUTPUTS 



MODE SELECTION 



PD/PGM 
118) 



Vpp ! V cc | OUTPUTS 
(211 (241 , 19-11, 13-17) I 



I '5 



Desel 


ct 


] 




Don't Care 




v,„ 


i" i 


♦ 5 




H.cjh Z 


Pov»e 


Down 






V|H 


; Do 


n't Care 


! *5 


♦ 5 




H.gh Z 


Progr 


am 




Pu 


sed Vi L to Vih 




V,h 


! *25 


*5 




Dim 


Progr 


am Verity 


I 




VlL 




V, L 


, *2S 


♦ 5 




Dout 


Progr 


am Inhibit 


1 




V, L 


i 


V|H 


! *25 | 


+5 


1 


High Z 



BLOCK DIAGRAM 



CHIP SELECT. 

POWER DOWN. AND 

PROG. LOGIC 



AO-A10 

ADDRESS 

INPUTS 



OUTPUT BUFFERS 
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PROGRAMMING 

The programming specifications are described in the PROM/ROM Programming Instructions on page 3-55 



Absolute Maximum Ratings* 

Temperature Under Bias -10°Cto+80 C 

Storage Temperature -65°C to +125 C 

All Input or Output Voltages with 

Respect to Ground +6V to -0.3V 

Vpp Supply Voltage with Respect 

to Ground +28V to -0.3V 

READ OPERATION 

D.C. and Operating Characteristics 

T A = 0°Cto 70°C, V CC [1 ' 21 = +5V ±5%, Vpp' 2 ) = V cc ±0.6V' 3 ] 



"COMMENT: Stresses above those listed under "Absolute Maxi- 
mum Ratings" may cause permanent damage to the device. This is a 
stress rating only and functional operation of the device at these or 
any other conditions above those indicated in the operational sec- 
tions of this specification is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect device 
reliability. 



Symbol 


Parameter 


Limits 


Unit 


Conditions 


Min. 


Typ.W 


Max. 


Ili 


Input Load Current 






10 


PA 


V| N = 5.25V 


Ilo 


Output Leakage Current 






10 


HA 


V 0U T = 5.25V 


Ippi (2 1 


Vpp Current 






5 


mA 


Vpp = 5.85V 


icci [21 


Vcc Current (Standby) 




10 


25 


mA 


PD/PGM = V| H ,CS = V, L 


ICC2 (21 


Vcc Current (Active) 




57 


100 


mA 


CS = PD/PGM = V| L 


V|L 


Input Low Voltage 


-0.1 




0.8 


V 




V,H 


Input High Voltage 


2.2 




Vcc+1 


V 




Vol 


Output Low Voltage 






0.45 


V 


Iql = 2.1 mA 


Vqh 


Output High Voltage 


2.4 






V 


I oh = -400/jA 



NOTES: 1. Vcc must be applied simultaneously or before Vpp and removed simultaneously or after Vpp. 

2. Vpp may be connected directly to Vcc except during programming. The supply current would then be the sum of Ice an d 'PP1 • 

3. The tolerance of 0.6V allows the use of a driver circuit for switching the Vpp supply pin from Vcc ' n rea d to 25V for program- 
ming. 

4. Typical values are for T A = 25° C and nominal supply voltages. 

5. This parameter is only sampled and is not 100% tested. 

6. t^cC2 ' s referenced to PD/PGM or the addresses, whichever occurs last. 

Typical Characteristics 



l CC CURRENT 

vs. 
TEMPERATURE 



ACCESS TIME 

vs. 
CAPACITANCE 



ACCESS TIME 

vs. 

TEMPERATURE 











































ICC2 ACTIVE CURRENT 

PD/PGM- V|L 

Vcc " 5V 








































ICCI STA 

PD/P 
V 


^JDBYCURR 
GM» V|H 
CC-5V 


EKiT 

















wo 

600 
600 
400 
300 
200 
100 





























































































































































VCC 


- 5V 






































































10 20 30 40 50 60 70 80 
TEMPERATURE l°C) 



100 200 300 400 500 600 700 800 
Cl IpF) 



30 40 60 60 70 80 
TEMPERATURE CO 
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A.C. Characteristics 

T A = 0°C to 70°C, V cc [11 = +5V ±5%, Vppl 2 ' = V C c 


±0.6V [31 










Symbol 


Parameter 


Limits 


Unit 


Test Conditions 


Min. 


Typ.W 


Max. 


Ucci 


Address to Output Delay 




250 


450 


ns 


PD/PGM = CS = V| L 


^002 


PD/PGM to Output Delay 




280 


450 


ns 


CS= V| L 


tco 


Chip Select to Output Delay 






120 


ns 


PD/PGM = V| L 


tpF 


PD/PGM to Output Float 







100 


ns 


CS= V| L 


tDF 


Chip Deselect to Output Float 







100 


ns 


PD/PGM = V, L 


T-OH 


Address to Output Hold 









ns 


PD/PGM = CS = V, L 



Capacitance 151 T A = 25°C, f = 1 MHz 



Symbol 


Parameter 


Typ. 


Max. 


Unit 


Conditions 


C|N 


Input Capacitance 


4 


6 


PF 


V lN = 0V 


C OUT 


Output Capacitance 


8 


12 


pF 


V O UT=0V 



NOTE: Please refer to page 2 for notes. 

WAVEFORMS 

A. Read Mode 
PD/PGM = V| L 



A.C. Test Conditions: 

Output Load: 1 TTL gate and C L = 100 pF 
Input Rise and Fall Times: <20 ns 
Input Pulse Levels: 0.8V to 2.2V 
Timing Measurement Reference Level: 

Inputs 1Vand2V 

Outputs 0.8V and 2V 




&_ Standby Mode 
CS = V il 




STANDBY MODE 



ACTIVE MODE 



DATA VALID FOR ADDRESS N 



DATA VALID FOR ADDRESS N* 



7-15 



2716 



ERASURE CHARACTERISTICS 

The erasure characteristics of the 2716 are such that erasure 
begins to occur when exposed to light with wavelengths 
shorter than approximately 4000 Angstroms (A). It should 
be noted that sunlight and certain types of fluorescent 
lamps have wavelengths in the 3000-4000A range. Data 
show that constant exposure to room level fluorescent 
lighting could erase the typical 2716 in approximately 3 
years, while it would take approximatley 1 week to cause 
erasure when exposed to direct sunlight. If the 2716 is to 
be exposed to these types of lighting conditions for ex- 
tended periods of time, opaque labels are available from 
Intel which should be placed over the 2716 window to 
prevent unintentional erasure. 

The recommended erasure procedure (see page 3-55) for 
the 2716 is exposure to shortwave ultraviolet light which 
has a wavelength of 2537 Angstroms (A). The integrated 
dose (i.e., UV intensity X exposure time) for erasure should 
be a minimum of 15 W-sec/cm 2 . The erasure time with this 
dosage is approximately 15 to 20 minutes using an ultra- 
violet lamp with a 12000 juW/cm 2 power rating. The 2716 
should be placed within 1 inch of the lamp tubes during 
erasure. Some lamps have a filter on their tubes which 
should be removed before erasure. 



DEVICE OPERATION 

The six modes of operation of the 2716 are listed in Table 
I. It should be noted that all inputs for the six modes are at 
TTL levels. The power supplies required are a +5V Vrx and 
a Vpp. The Vpp power supply must be at 25V during the 
three programming modes, and must be at 5V in the other 
three modes. 



TABLE I. MODE SELECTION 



^~\^ PINS 
MODE ^\^ 


PD/PGM 
1181 


CS 
(201 


Vpp 
(21) 


Vcc 
(24) 


OUTPUTS 
(9 11, 13-171 


Read 


v, L 


VlL 


+5 


+5 


D OUT 


Deselect 


Don't Care 


V|H 


+5 


+5 


H.ghZ 


Power Down 


V|H 


Don't Care 


+ 5 


+5 


HighZ 


Program 


Pulsed V| L to V| H 


V|H 


+25 


+5 


Din 


Program Verify 


VlL 


VlL 


+25 


+5 


Dout 


Program Inhibit 


V|L 


V| H 


+25 


+5 


High Z 



READ MODE 

Data is available at the outputs in the read mode. Data is 
available 450 ns (tAcc[ from stable addresses with CS low 
or 120 ns (tco) Trom CS with addresses stable. 



DESELECT MODE 

The outputs of two or more 2716s may be OR-tied to- 
gether on the same data bus. Only one 2716 should have its 
outputs selected (CS low) to prevent data bus contention 
between 2716s in this configuration. The outputs of the 
other 2716s should be deselected with the CS input at a 
high TTL level. 

POWER DOWN MODE 

The 2716 has a power down mode which reduces the active 
power dissipation by 75%, from 525 mW to 132 mW. 
Power down is achieved by applying a TTL high signal to 
the PD/PGM input. In power down the outputs are in a 
high impedance state, independent of the CS input. 

PROGRAMMING 

Initially, and after each erasure, all bits of the 2716 are in 
the "1" state. Data is introduced by selectively program- 
ming "0's" into the desired bit locations. Although only 
"0's" will be programmed, both "1's" and "0's" can be 
presented in the data word. The only way to change a "0" 
to a "1" is by ultraviolet light erasure. 

The 2716 is in the programming mode when the Vpp power 
supply is at 25V and CS is at V, H . The data to be pro- 
grammed is applied 8 bits in parallel to the data output 
pins. The levels required for the address and data inputs are 
TTL. 

When the addresses and data are stable, a 50 msec, active 
high, TTL program pulse is applied to the PD/PGM input. 
A program pulse must be applied at each address location 
to be programmed. You can program any location at any 
time — either individually, sequentially, or at random. 
The program pulse has a maximum width of 55 msec. The 
2716 must not be programmed with a DC signal applied to 
the PD/PGM input. 

Programming of multiple 2716s in parallel with the same 
data can be easily accomplished due to the simplicity of 
the programming requirements. Like inputs of the paral- 
leled 2716s may be connected together when they are pro- 
grammed with the same data. A high level TTL pulse 
applied to the PD/PGM input programs the paralleled 
2716s. 

PROGRAM INHIBIT 

Programming of multiple 2716s in parallel with different 
data is also easily accomplished. Except for PD/PGM, all 
like inputs (including CS) of the parallel 2716s may be 
common. A TTL level program pulse applied to a 2716's 
PD/PGM input with V PP at 25V will program that 2716. 
A low level PD/PGM input inhibits the other 2716s from 
being programmed. 

PROGRAM VERIFY 

A verify should be performed on the programmed bits to 
determine that they were correctly programmed. The verify 
may be performed wth Vpp at 25V. Except during pro- 
gramming and program verify, Vpp must be at 5V. 
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8101A-4 
1024 BIT STATIC MOS RAM 
WITH SEPARATE I/O 

* 450 nsec Access Time Maximum 

* 256 Word by 4 Bit Organization 



Single +5V Supply Voltage 

Directly TTL Compatible: All Inputs and 
Outputs 

Static MOS: No Clocks or Refreshing 
Required 

Simple Memory Expansion: Chip Enable 
Input 



b Powerful Output Drive Capability 

b Low Cost Packaging: 22 Pin Plastic Dual 
In-Line Configuration 

n Low Power: Typically 150mW 

b Three-State Output: OR-Tie Capability 

b Output Disable Provided for Ease of Use 
in Common Data Bus Systems 



The Intel® 81 01 A-4 is a 256 word by 4-bit static random access memory element using N-channel MOS devices integrated 
on a monolithic array. It uses fully DC stable (static) circuitry and therefore requires no clocks or refreshing to operate. 
The data is read out nondestructively and has the same polarity as the input data. 

The 8101A-4 is designed for memory applications where high performance, low cost, large bit storage, and simple 
interfacing are important design objectives. 

It is directly TTL compatible in all respects: inputs, outputs, and a single +5V supply. Two chip-enables allow easy 
selection of an individual package when outputs are OR-tied. An output disable is provided so that data inputs and outputs 
can be tied for common I/O systems. The output disable function eliminates the need for bi-directional logic in a common 
I/O system. 

The Intel® 8101A-4 is fabricated with N-channel silicon gate technology. This technology allows the design and 
production of high performance, easy-to-use MOS circuits and provides a higher functional density on a monolithic chip 
than either conventional MOS technology or P-channel silicon gate technology. 

Intel's silicon gate technology also provides excellent protection against contamination. This permits the use of low cost 
plastic packaging. 



PIN CONFIGURATION 



LOGIC SYMBOL 




— *<) 



R/W CE2 CE1 



TTT 





PIN NAMES 


DI,DI 4 
V A 7 


DATA INPUT 
ADDRESS "INPUTS 


CE 2 CHIP ENABLE 2 


OD OUTPUT DISABLE 


R/W 


READ/WRITE INPUT 


DO,-D0 4 DATA OUTPUT 


CE, 


CHIP ENABLE 1 


V cc POWER (+5VI 



BLOCK DIAGRAM 




O" PIN NUMBERS 
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8101A-4 



ABSOLUTE MAXIMUM RATINGS* 

Ambient Temperature Under Bias -10°C to 80°C 

Storage Temperature -65°C to +150 C 

Voltage On Any Pin 

With Respect to Ground -0.5V to +7V 

Power Dissipation 1 Watt 



* COM ME NT: 

Stresses above those listed under "Absolute Maximum 
Rating" may cause permanent damage to the device. This 
is a stress rating only and functional operation of the de- 
vice at these or at any other condition above those indi- 
cated in the operational sections of this specification is 
not implied. Exposure to absolute maximum rating con- 
ditions for extended periods may affect device reliability. 



D.C. AND OPERATING CHARACTERISTICS 

T A = 0°C to 70°C, V cc = 5V ±5% unless otherwise specified. 



Symbol 


Parameter 


Min. 


Typ. [11 


Max. 


Unit 


Test Conditions 


Ili 


Input Current 




1 


10 


juA 


V| N =0 to 5.25V 


'loh 


I/O Leakage Current [2l 




1 


10 


MA 


Output Disabled, V O ut =4 -0V 


•lol 


I/O Leakage Current! 2 ' 




-1 


-10 


/uA 


Output Disabled, Vout =0 - 45V 


'cci 


Power Supply 
Current 




35 


55 


mA 


V, N = 5.25V, l = 0mA 
T A = 25° C 


'CC2 


Power Supply 
Current 






60 


mA 


V| N = 5.25V, l = 0mA 

T A = 0°C 


V|L 


Input "Low" Voltage 


-0.5 




+0.8 


V 




V|H 


Input "High" Voltage 


2.0 




Vcc 


V 




Vol 


Output "Low" Voltage 






+0.45 


V 


I l = 2.0mA 


VOH 


Output "High" 
Voltage 


2.4 






V 


l 0H = -400/jA 



TYPICAL D.C. CHARACTERISTICS 



OUTPUT SOURCE CURRENT VS. 
OUTPUT VOLTAGE 



OUTPUT SINK CURRENT VS. 
OUTPUT VOLTAGE 







AMBI 


ENTTE 


MPERA 


TURE 








-25°C 
70°C 












































V CC=* 
OUTPU 


75V 
T "HIG 


H'TYP 


ICAL 























AMBI 


NTTE 


WPERA 


TURE = 


0°C^ 














25°C 




























70°C 












V cc =4 
OUTPU 


.75V 
T "LOV 


VTYP 


CAL 























NOTES: 1. Typical values are for T A = 25°C and nominal supply voltage. 
2. Input and Output tied together. 
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8101A-4 
A.C. CHARACTERISTICS 

READ CYCLE T A = 0°C to 70°C, V C c = 5V ±5%, unless otherwise specified. 



Symbol 


Parameter 


Min. 


T I 11 

Typ. 


Max. 


Unit 


Test Conditions 


tRC 


Read Cycle 


450 






ns 




tA 


Access Time 






450 


ns 




l CO 


Chip Enable To Output 






310 


ns 




t OD 


Output Disable To Output 






250 


ns 


(See Below) 


t DF l2l 


Data Output to High Z State 







200 


ns 




T-OH 


Previous Read Data Valid 
after change of Address 


40 






ns 





WRITE CYCLE 



Symbol 


Parameter 


Min. 


Typ. 


Max. 


Unit 


Test Conditions 


*wc 


Write Cycle 


270 






ns 




*AW 


Write Delay 


20 






ns 




*CW 


Chip Enable To Write 


250 






ns 




tow 


Data Setup 


250 






ns 


(See Below) 


l DH 


Data Hold 









ns 




t W p 


Write Pulse 


250 






ns 




%R 


Write Recovery 









ns 




tps 


Output Disable Setup 


20 






ns 





A.C. CONDITIONS OF TEST 

t r ,tf 20 ns 

Input Levels 0.8V or 2.0V 

Timing Reference 1.5V 

Load 1 TTL Gate and C L = 100 pF 



WAVEFORMS 

READ CYCLE 



[31 



CAPACITANCE t a = 25°c, f = 1MHz 



3RESS V 



(COMMON I/O) 14 ' 



DATA 
OUT 



\ 



/z 



\ 



J( 



y ADDRESS >( 



/z=\ 



Symbol 


Test 


Limits (pF) 


Typ.lD 


Max. 


C IN 


Input Capacitance 

(All Input Pins) V, N = 0V 


4 


8 


COUT 


Output Capacitance Vqut 


= 0V 


8 


12 



WRITE CYCLE 



(COMMON I/O] 



I NOTES: 1. Typical values are for T A = 25°C and nominal supply voltage. 

2. trjp IS w ' tri respect to the trailing edge of CEi, CE2, or OD, 
whichever occurs first. 

3. This parameter is periodically sampled and is not 1 00% tested. 




4. OD should be tied low for separate I/O operation. 
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8111A-4 

1024 BIT STATIC MOS RAM 

WITH COMMON I/O 

* 450 nsec Access Time Maximum 

* 256 Word by 4 Bit Organization 



a Single +5V Supply Voltage 

h Directly TTL Compatible: All Inputs 
and Outputs 

□ Static MOS: No Clocks or Refreshing 
Required 

a Simple Memory Expansion: Chip Enable 
Input 



□ Powerful Output Drive Capability 

Q Low Cost Packaging: 18 Pin Plastic Dual 
In-Line Configuration 

□ Low Power: Typically 150mW 

a Three-State Output: OR-Tie Capability 

o Output Disable Provided for Ease of Use 
in Common Data Bus Systems 



The Intel® 81 1 1 A-4 is a 256 word by 4-bit static random access memory element using N-channel MOS devices integrated 
on a monolithic array. It uses fully DC stable (static) circuitry and therefore requires no clocks or refreshing to operate. 
The data is read out nondestructively and has the same polarity as the input data. Common input/output pins are provided. 

The 81 1 1 A-4 is designed for memory applications in small systems where high performance, low cost, large bit storage, 
and simple interfacing are important design objectives. 

It is directly TTL compatible in all respects: inputs, outputs, and a single +5V supply. Separate chip enable (CE) leads allow 
easy selection of an individual package when outputs are OR-tied. 

The Intel® 81 11 A-4 is fabricated with N-channel silicon gate technology. This technology allows the design and 
production of high performance, easy-to-use MOS circuits and provides a higher functional density on a monolithic chip 
than either conventional MOS technology or P-channel silicon gate technology. 

Intel's silicon gate technology also provides excellent protection against contamination. This permits the use of low cost 
plastic packaging. 



PIN CONFIGURATION 

Z]Vcc 

A 2 (Z| 2 17| I Aj 
Ai^ 3 16 | |R/W 

AoLj4 ISpHCE, 

81 11 A-4 



A 5 |Z 
A 6 [Z 
A 7 [Z 7 
GND | 

odC 



JI/O4 
13 1 |l/Q 3 
12 |l/Q 2 
11 |l/Q 1 

10 ;~ JCE 2 



LOGIC SYMBOL 





A o 






A, 


I/O, 




A 2 


i/o 2 


— 


A3 V°3 
81 11 A-4 

A„ "O4 




A 6 


OD 




A 7 

R/W 


CE, CE 2 



n 



PIN NAMES 



A0A7 


ADDRESS INPUTS 


OD 


OUTPUT DISABLE 


R/W 


READ/WRITE INPUT 


CE, 


CHIP ENABLE 1 


CE2 


CHIP ENABLE 2 


I/O,- I/O4 


DATA INPUT/OUTPUT 



BLOCK DIAGRAM 




Q = PIN NUMBERS 



8111A-4 



ABSOLUTE MAXIMUM RATINGS* 

Ambient Temperature Under Bias -10°Cto 80°C 

Storage Temperature -65°C to +150°C 

Voltage On Any Pin 

With Respect to Ground -0.5V to +7V 

Power Dissipation 1 Watt 



* COMMENT: 

Stresses above those listed under "Absolute Maximum 
Rating 'may cause permanent damage to the device. This 
is a stress rating only and functional operation of the de- 
vice at these or at any other condition above those indi- 
cated in the operational sections of this specification is 
not implied. Exposure to absolute maximum rating con- 
ditions for extended periods may affect device reliability. 



D.C. AND OPERATING CHARACTERISTICS 

T/\ = C to 70°C, Vcc = 5V ±5% , unless otherwise specified. 



Symbol 


Parameter 


Min. 


Typ.M 


Max. 


Unit 


Test Conditions 


l|_l 


Input Load Current 




1 


10 


juA 


V, N = to 5.25V 


!loh 


I/O Leakage Current 




1 


10 


MA 


Output Disabled, V|/ O =4.0V 


'lol 


I/O Leakage Current 




-1 


-10 


fiA 


Output Disabled, V|/ O =0.45V 


'cCI 


Power Supply 
Current 




35 


55 


mA 


V, N = 5.25V 

I I/O = 0mA, T A = 25°C 


'CC2 


Power Supply 
Current 






60 


mA 


V, N = 5.25V 

l| /o = 0mA, T A =0°C 


VlL 


Input Low Voltage 


-0.5 




0.8 


V 




V|H 


Input High Voltage 


2.0 




v C c 


V 




Vol 


Output Low Voltage 






0.45 


V 


l L = 2.0mA 


VqH 


Output High 
Voltage 


2.4 






V 


Iqh =-400mA 



OUTPUT SOURCE CURRENT VS. 
OUTPUT VOLTAGE 



OUTPUT SINK CURRENT VS. 
OUTPUT VOLTAGE 







AMBI 


ENTTE 


MPERA 


TURE 








-25°C 
-70°C 












































v cc= 4 
OUTPU 


75V 
T "HIG 


H-TYP 


ICAL 























AMBI 


NTTE 


MPERA 


TURE = 


tycy 














25°C 




























70°C 












V cc -4 
OUTPU 


75V 
T "LOV 


V'TYP 


CAL 























0.5 1.0 

V 0L (VOLTS) 



NOTE: 1. Typical values are for T A = 25° C and nominal supply voltage. 
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8111A-4 
A.C. CHARACTERISTICS 

READ CYCLE T A = 0°C to 70°C, V cc = 5V ±5%, unless otherwise specified. 



Symbol 


Parameter 


Min. 


Typ. 


Max. 


Unit 


Test Conditions 


tRC 


Read Cycle 


450 






ns 




t A 


Access Time 






450 


ns 




tco 


Chip Enable To Output 






310 


ns 




tfJD 


Output Disable To Output 






250 


ns 


(See Below) 


t DF [2l 


Data Output to High Z State 







200 


ns 




^OH 


Previous Read Data Valid 
after change of Address 


40 






ns 





WRITE CYCLE 



Symbol 


Parameter 


Min. 


, HI 
Typ. 


Max. 


Unit 


Test Conditions 


%c 


Write Cycle 


270 






ns 




*AW 


Write Delay 


20 






ns 




l CW 


Chip Enable To Write 


250 






ns 




tow 


Data Setup 


250 






ns 


(See Below) 


tDH 


Data Hold 









ns 


*WP 


Write Pulse 


250 






ns 




%R 


Write Recovery 









ns 




t DS 


Output Disable Setup 


20 






ns 





A.C. CONDITIONS OF TEST 

t r ,tf . . 20 ns 

Input Levels 0.8V or 2.0V 

Timing Reference 1.5V 

Load 1 TTL Gate and C L = 100 pF 



[3] 
CAPACITANCE T A = 25°C, f = 1 MHz 



Symbol 


Test 


Limits (pF) 


TypJH 


Max. 


C|N 


Input Capacitance 

(All Input Pins) V, N = 0V 


4 


8 


C|/o 


I/O Capacitance V|/o = 0V 


10 


15 



WAVEFORMS 

READ CYCLE 



WRITE CYCLE 



D( 



CHIP 

ENABLES 

(CE1.CE2) 



OUTPUT 
DISABLE 



:>< 



V ADDRESS V 



/ 



CHIP 

ENABLES 

(CE..CE,) 



'-\V Dt 



T3 



)C 



/■ 



s 



%:- 



NOTES: 1. Typical values are for T/\ = 25°C and nominal supply voltage. 

2. top is with respect to the trailing edge of CE-| , CE2, or OD, whichever occurs first. 

3. This parameter is periodically sampled and is not 1 00% tested. 
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5101 FAMILY 
256 X 4 BIT STATIC CMOS RAM 



P/N 


Typ. 


Current @ 2V Typ. Current 
(MA) (pA) 


@5V 


Max Access 
(ns) 


5101L 




0.14 0.2 




650 


5101L-1 




0.14 0.2 




450 


5101L-3 




0.70 1.0 




650 


5101-8 




10.0 




800 



b Single +5V Power Supply 

□ Ideal for Battery 
Operation (5101L) 



□ Directly TTL Compatible: 
All Inputs and Outputs 

p Three-State Output 



The Intel® 5101 is an ultra-low power 1024-bit (256 words X 4 bits) static RAM fabricated with an advanced ion-implanted 
silicon gate CMOS technology. The device has two chip enable inputs. Minimum standby current is drawn by this device when 
CE2 is at a low level. When deselected the 5101 draws from the single 5-volt supply only 10 microamps. This device is ideally 
suited for low power applications where battery operation or battery backup for non-volatility are required. 

The 5101 uses fully DC stable (static) circuitry; it is not necessary to pulse chip select for each address transition. The data is read 
out non-destructively and has the same polarity as the input data. All inputs and outputs are directly TTL compatible. The 5101 
has separate data input and data output terminals. An output disable function is provided so that the data inputs and outputs may 
be wire OR-ed for use in common data I/O systems. 

The 5101 L has the additional feature of guaranteed data retention at a power supply voltage as low as 2.0 volts. 

A pin compatible N-channel static RAM, the Intel® 2101 A, is also available for low cost applications where a 256 X 4 organiza- 
tion is needed. 

The Intel ion-implanted, silicon gate, Complementary MOS (CMOS) process allows the design and production of ultra-low power, 
high performance memories. 



PIN CONFIGURATION 



LOGIC SYMBOL 




*0 




A, 




A 7 




A 3 




*4 




A 5 




\ 




*7 




Dl, 


DO 


Dl, 


DO 


Dl, 


DO 


Dl 4 


DO 


OD 




R/W 


CE2 CE1 



T-TT 



CE, 


CE 2 


OD 


R/W 


Din 


Output 


Mode 


H 


X 


X 


X 


X 


HighZ 


Not Selected 


X 


L 


X 


X 


X 


HighZ 


Not Selected 


X 


X 


H 


H 


X 


HighZ 


Output Disebled 


L 


H 


H 


L 


X 


HighZ 


Write 


L 


H 


L 


L 


X 


Din 


Write 


L 


H 


L 


H 


X 


Dout 


Read 



BLOCK DIAGRAM 




>0^>o 



A5 A 6 A 7 



O -PIN NUMBERS 
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5101 FAMILY 



Absolute Maximum Ratings * 

Ambient Temperature Under Bias -10°C to 80°C 

Storage Temperature -65°C to +150°C 

Voltage On Any Pin 

With Respect to Ground .... -0.3V to V cc +0.3V 

Maximum Power Supply Voltage +7.0V 

Power Dissipation 1 Watt 

D. C. and Operating Characteristics 

Ta = 0°C to 70°C, Vcc = 5V ±5% unless otherwise specified. 



*COMMENT: 

Stresses above those fisted under "Absolute Maximum 
Rating ' may cause permanent damage to the device. This 
is a stress rating only and functional operation of the device 
at these or at any other condition above those indicated in 
the operational sections of this specification is not implied. 
Exposure to absolute maximum rating conditions for ex- 
tended periods may affect device reliability. 



Symbol 


Parameter 


5101 L and 5101 L-1 

Limits 
Min. Typ.ni Max. 


51 01 L-3 
Limits 
Min. Typ.l 1 ] 


Max. 


5101-8 

Limits 

Min. Typ.Ml Max. 


Units 


Test Conditions 


l L2 [2] 


Input Current 


5 


5 


5 


nA 




IlLC-lt 2 ! 


Output Leakage Current 


1 


1 


2 


/LtA 


CE1=2.2V, V UT= 
to V C c 


■cci 


Operating Current 


9 22 


9 


22 


11 25 


mA 


V|N=Vcc» Except 
CE1 < 0.65V, 
Outputs Open 


'CC2 


Operating Current 


13 27 


13 


27 


15 30 


mA 


V| N =2.2V, Except 
CET < 0.65V, 
Outputs Open 


iced 2 ' 


Standby Current 


10 


200 


500 


juA 


CE2<0.2V,T A = 
70° C 


V|L 


Input Low Voltage 


-0.3 0.65 


-0.3 


0.65 


-0.3 0.65 


V 




V| H 


Input High Voltage 


2.2 V cc 


2.2 


Vcc 


2.2 V cc 


V 




Vol 


Output Low Voltage 


0.4 


0.4 


0.4 


V 


l O L=2.0mA 


Voh 


Output High Voltage 


2.4 


2.4 


2.4 


V 


Iqh = -1-0 m A 



Low Vcc Data Retention Characteristics (For 5101L, 5101L-1 and 5101 L-3) T A = 0°Cto 70°C 



Symbol 


Parameter 


Min. 


Typ.ni 


Max. 


Units 


Test Conditions 


v D r 


Vcc f° r Data Retention 


2.0 






V 


CE2<0.2V . 




'CCDR1 


5101 Lor 5101 L-1 Data Retention 
Current 




0.14 


10 


MA 


V DR =2.0V, 
T A =70°C 


'CCDR2 


5101 L-3 Data Retention Current 




0.70 


200 


ma 


V DR =2.0V, 
T A =70°C 


*CDR 


Chip Deselect to Data Retention Time 









ns 






tR 


Operation Recovery Time 


tR C I 3 ' 






ns 







NOTES: 

1 . Typical values are Ta = 25° C and nominal supply voltage. 

2. Current through all inputs and outputs included in IccL measurement. 
3- *RC = Read Cycle Time. 
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5101 FAMILY 



Low Vcc Data Retention Waveform 



Typical IrjCDR Vs. Temperature 




CHIP ENABLE (CE2) 



© 4.75V 

© V DR 

® © V 'H 

W © 0.2V 





Vcc - 2V 










VlN 


= 2V 

























10 20 30 40 50 
TEMPERATURE <°C) 



A.C. Characteristics T A = 0°C to 70°C, V CC = 5V ±5%, unless otherwise specified. 
READ CYCLE 



Symbol 


Parameter 


5101 L-1 

Limits (ns) 

Min. Max. 


5101Land 

5101L-3 

Limits (ns) 

Min. Max. 


5101-8 

Limits (ns) 

Min. Max. 


t-RC 


Read Cycle 


450 


650 


800 


tA 


Access Time 


450 


650 


800 


tcoi 


Chip Enable (CE 1) to Output 


400 


600 


800 


T-C02 


Chip Enable (CE 2) to Output 


500 


700 


850 


tOD 


Output Disable to Output 


250 


350 


450 


tDF 


Data Output to High Z State 


130 


150 


200 


tOH1 


Previous Read Data Valid with 
Respect to Address Change 











T-OH2 


Previous Read Data Valid with 
Respect to Chip Enable 












WRITE CYCLE 



twc 


Write Cycle 


450 


650 


800 


*AW 


Write Delay 


130 


150 


200 


tcwi 


Chip Enable (CEl ) to Write 


350 


550 


650 


tCW2 


Chip Enable (CE 2) to Write 


350 


550 


650 


T-DW 


Data Setup 


250 


400 


450 


tDH 


Data Hold 


50 


100 


100 


twp 


Write Pulse 


250 


400 


450 


T-WR 


Write Recovery 


50 


50 


100 


*DS 


Output Disable Setup 


130 


150 


200 



A. C. CONDITIONS OF TEST 

Input Pulse Levels: +0.65 Volt to 2.2 Volt 

Input Pulse Rise and Fall Times: 20nsec 

Timing Measurement Reference Level: 1.5 Volt 
Output Load: 1 TTL Gate and C L - 100pF 



NOTES: 1. Typical values are for T A = 25° C and nominal supply voltage. 
2. This parameter is periodically sampled and is not 100% tested. 



Capacitance t a = 25°c, f = 1 mh z 



Symbol 


Test 


Limits (pF) 


Typ. 


Max. 


C IN 


Input Capacitance 

(All Input Pins) V, N = 0V 


4 


8 


Qdut 


Output Capacitance Vqut = 0V 


8 


12 



7-27 



5101 FAMILY 



Waveforms 



READ CYCLE 



5 A 



•£ 



(COMMON I/O)'" 



\ 



\ 



X 



WRITE CYCLE 



y AODRESS >£ 



/ 



■y 



(COMMON I/O) 1 ' 



NOTES: 

1. OD may be tied low for separate I/O operation. 

2. During the write cycle, OD is "high" for common I/O and 
"don't care" for separate I/O operation. 



)C 



\ 



/ 






DATA IN 
STABLE 



x.:. 
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8212 
8-BIT INPUT/OUTPUT PORT 



a Fully Parallel 8-Bit Data Register and 
Buffer 

a Service Request Flip-Flop for Interrupt 
Generation 

a Low Input Load Current — 0.25 mA Max 

a 3-State Outputs 

a Outputs Sink 15 mA 



a 3.65V Output High Voltage for Direct 
Interface to 8080 CPU or 8008 CPU 

a Asynchronous Register Clear 

a Replaces Buffers, Latches, and Multi- 
plexers in Microcomputer Systems 

a Reduces System Package Count 



The Intel® 8212 input/output port consists of an 8-bit latch with 3-state output buffers along with control and device 
selection logic. Also included is a service request flip-flop for the generation and control of interrupts to the 
microprocessor. 

The device is multimode in nature. It can be used to implement latches, gated buffers or multiplexers. Thus, all of the 
principal peripheral and input/output functions of a microcomputer system can be implemented with this device. 

•Note: The specifications for the 3212 are identical with those for the 8212. 



PIN CONFIGURATION 
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LOGIC DIAGRAM 
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PIN NAMES 
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FUNCTIONAL DESCRIPTION 
Data Latch 

The 8 flip-flops that make up the data latch are of a 

"D" type design. The output (Q) of the flip-flop will 

follow the data input (D) while the clock input (C) is 

high. Latching will occur when the clock (C) returns 

low. 

The d ata l atch is cleared by an asynchronou s re set 

input (CLR). (Note: Clock (C) Overides Reset (CLR).) 

Output Buffer 

The outputs of the data latch (Q) are connected to 
3 -state, non-inverting output buffers. These buffers 
have a common control line (EN); this control line 
either enables the buffer to transmit the data from 
the outputs of the data latch (Q) or disables the 
buffer, forcing the output into a high impedance 
state. (3 -state) 

This high-impedance state allows the designer to 
connect the 8212 directly onto the microprocessor 
bi-directional data bus. 

Control Logic 

The 8212 has control inputs DS1, DS2, MD and 
STB. These inputs are used to control device selec- 
tion, data latching, output buffer state and service 
request flip-flop. 

DS1, DS2 (Device Select) 

The se 2 inputs are used for dev ice selection. When 
DS1 is low and DS2 is high (DS1 • DS2) the device is 
selected. In the selected state the output buffer is 
enabled and the service request flip-flop (SR) is 
asynchronously set. 

MD(Mode) 

This input is used to control the state of the output 
buffer and to determine the source of the clock input 
(C) to the data latch. 

When MD is high (output mode) the output buffers 
are enabled and the source of clock (C) to the data 
latch is from the device selection logic (DS1 • DS2). 
When MD is low (input mode) the output buffer state 
is determined by the device selection logic (DS1 • 
DS2) and the source of clock (C) to the data latch is 
the. STB (Strobe) input. 

STB (Strobe) 

This input is used as the clock (C) to the data latch 
for the input mode MD = 0) and to synchronously 
reset the service request flip-flop (SR). 

Note that the SR flip-flop is negative edge triggered. 



Service Reqeust Flip-Flop 

The (SR) flip-flop is used to generate and control 
interrupts in microcomputer systems. It is asyn- 
chronously set by the CLR input (active low). When 
the (SR) flip-flop is set it is in the non-interrupting 
state. 

The output of the (SR) flip-flop (Q) is connected to 
an inverting input of a "NOR" gate. The other input 
to the "NOR" gate is non-inverting and is connected 
to the device selection logic (DS1 • DS2). The output 
of the "NOR" gate (iNT) is active low (interrupting 
state) for connection to active low input priority 
generating circuits. 

SERVICE REQUEST FF 



LECTION r * I C^Q 



(T> DS1 
[i]r> DS2 

|T> MD - 
[TT> STB- 

GD>D'l- 
f£>DI 2 - 

E> D '3- 
[9>DI 4 - 

[H> DI 5 " 

[UJ>DI 6 - 
[20>DI 7 - 
[|?>D1 8 - 

[T4>cTr- 



\ 



O 




1/^ °- INTf23> 
■ Li ^ (ACTIVE LOW) 



DATA LATCH 



:tive low: I • 



' I output 

I BUFFER 









E> 



D0 2 [S> 

--^-[ D °3lF> 



i rro> 



D0 5 (T|> 



do 6 [T7> 



-£>T D °7Ll 



do 8 nj> 



L 



J_ J 



MO 


(DS 


1 DS 2 ) 











1 
1 














1 




1 




1 
1 



DATA OUT EQUALS 
3STATE 
3STATE 
DATA LATCH 
DATA LATCH 
DATA LATCH 
DATA IN 
DATA IN 
DATA IN 




•INTERNAL SR FLIP FLOP 



CLR - RESETS DATA LATCH 
SETSSR FLIP FLOP 
(NO EFFECT ON OUTPUT BUFFERI 



Figure 1. Service Flip-Flop Function 
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APPLICATIONS OF THE 8212 - FOR 
MICROCOMPUTER SYSTEMS 

• Basic schematic symbols 

• Gated buffer 

• Bidirectional bus driver 

• Interrupting input port 



• Interrupt instruction port 

• Output port 

• 8080A status latch 

• 8085A address latch 



Basic Schematic Symbols 

Two examples of ways to draw the 8212 on system 
schematics — (1) the top being the detailed view 
showing pin numbers, and (2) the bottom being the 
symbolic view showing the system input or output 



as a system bus (bus containing 8 parallel lines). 
The output to the data bus is symbolic in referenc- 
ing 8 parallel lines. 



INPUT DEVICE 




SYSTEM 
INPUT 



OUTPUT DEVICE 

" r 




^> 



m 



>o 



SYSTEM 
UTPUT 



Figure 2. Basic Schematic Symbols 



Gated Buffer (3-State) 

The simplest use of the 8212 is that of a gated 
buffer. By tying the mode signal low and the strobe 
input high, the data latch is acting as a straight 
through gate. The output buffers are then enabled 
from the device selection logic DS1 and DS2. 
When the device selection logic is false, the outputs 
are 3-state. 

When the device selection logic is true, the input 
data from the system is directly transferred to the 
output. The input data load is 250 micro amps. The 
output data can sink 15 milli amps. The minimum 
high output is 3.65 volts. 




N OUTPUT 

\ DATA 

Y (15mA) 

(3.65V MIN) 



Figure 3. Gated Buffer (3-State) 
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Bidirectional Bus Driver 

A pair of 821 2's wired (back-to-back) can be used 
as a symmetrical drive, bi-directional bus driver. 
The devices are controlled by the data bus input 
control which is connected to DS1 on the first 8212 
and to DS2 on the second. One device is active, and 
acting as a straight through buffer the other is in 
3-state mode. This is a very useful circuit in small 
system design. 




rj=r 



Interrupting Input Port 

This use of an 8212 is that of a system input port 
that accepts a strobe from the system input source, 
which in turn clears the service request flip-flop 
and interrupts the processor. The processor then 
goes through a service routine, identifies the port, 
and causes the device selection logic to go true — 
enabling the system input data onto the data bus. 



Figure 4. Bidirectional Bus Driver 




H>- 



TO PRIORITY CKT 
(ACTIVE LOW) 

TO CPU 
INTERRUPT INPUT 



Interrupt Instruction Port 

The 8212 can be used to gate the interrupt instruc- 
tion, normally RESTART instructions, onto the data 
bus. The device is enabled from the interrupt 
acknowledge signal from the microprocessor and 
from a port sele ction signal. This signal is normally 
tied to ground. (DS1 could be used to multiplex a 
variety of interrupt instruction ports onto a com- 
mon bus). 



Figure 5. Interrupting Input Port 



RESTART I N . 

INSTRUCTION ( > 

(RSTO — RST7) ^TV 



(DSD PORT SELECTION 
INTERRUPT ACKNOWLEDGE 




Figure 6. Interrupt Instruction Port 
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Output Port (With Handshaking) 

The 8212 can be used to transmit data from the data 
bus to a system output. The output strobe could be 
a hand-shaking signal such as "reception of data" 
from the device that the system is outputting to. It 
in turn, can interrupt the system signifying the re- 
ception of data. The selection of th e port comes 
from the device selection logic. (DS1 • DS2) 



SYSTEM 
INTERRUPT 




OUTPUT STROBE 



SYSTEM OUTPUT 



SYSTEM RESET 

PORT SELECTION 
-(LATCH CONTROL) 
(DSLDS2) 



Figure 7. Output Port (With Handshaking) 



8080 Status Latch 

Here the 8212 is used as the status latch for an 8080 
microcomputer system. The input to the 8212 latch 
is directly from the 8080 data bus. Timing shows 
that when the SYNC signal is true, which is con- 
nected to the DS2 input and the phase 1 signal is 
true, which is a TTL level coming from the clock 
generator; then, the status data will be latched into 
the 8212. 



Note: The mode signal is tied high so that the output 
on the latch is active and enabled all the time. 
It is shown that the two areas of concern are the 
bidirectional data bus of the microprocessor and the 
controLbus. 
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\ 
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Figure 8. 8080 Status Latch 
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8085A Low-Order Address Latch 

The 8085A microprocessor uses a multiplexed address/ 
data bus that contains the low order 8-bits of address 
information during the first part of a machine cycle. The 
same bus contains data at a later time in the cycle. An 
address latch enable (ALE) signal is provided by the 8085A 
to be used by the 821 2 to latch the address so that it may be 
available through the whole machine cycle. Note: In this 
configuration, the MODE input is tied high, keeping the 
8212's output buffers turned on at all times. 




Do 
Di 
D 2 
D 3 
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D 5 
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DATA BUS 



Vcc 
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DH STB DO, 
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■A 
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X 
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Figure 9. 8085A Low-Order Address Latch 



7-34 



8212 



ABSOLUTE MAXIMUM RATINGS* 

Temperature under bias plastic o Cto75 o C 

Storage temperature 0°C to 75 °C 

All output or supply voltages -0.5V to +7V 

All input voltages - 1.0V to + 5.5V 

Output currents 100 mA 



"COMMENT: Stresses above those listed under "Absolute Maximum 
Ratings" may cause permanent damage to the device. This is a stress 
rating only and functional operation of the device at these or at any 
other condition above those indicated in the operational sections of 
this specification is not implied. 



D.C. CHARACTERISTICS 

T A = 0°C to +75°C Vrc = +5V ±5% 



Symbol 


Parameter 


Limits 


Unit 




Min. 


Typ. 


Max. 




l F Input Load Current 

ACK, DS 2 , CR, DI,-DI 8 Inputs 


-.25 


mA 


V F = .45V 


If 


Input Load Current 
MD Input 


-.75 


mA 


V F = .45V 


If Input Load Current 
DS, Input 


-1.0 


mA 


V F = .45V 


Ir 


Input Leakage Current 
ACK, DS.CR, DI.-DI, Inputs 


10 


/xA 


v R < v cc 


Ir 


Input Leakage Current 
MO Input 


30 


/xA 


v R <v cc 


Ir 


Input Leakage Current 
DS Input 


40 


[J.A 


v R < v cc 


V c 


Input Forward Voltage Clamp 


-1 


V 


l c = -5 mA 


V, L 


Input "Low" Voltage 


.85 


V 


V IH 


Input "High" Voltage 


2.0 


V 


Vol 


Output "Low" Voltage 


.45 


V 


Iol = 15 mA 


Voh 


Output "High" Voltage 


3.65 


4.0 




V 


I oh = -1 mA 


Isc 


Short Circuit Output Current 


-15 




-75 


mA 


V = 0V, V cc = 5.0V 


lo 


Output Leakage Current 
High Impedance State 


20 


/xA 


V = .45V/5.25V 


Ice 


Power Supply Current 




90 


130 


mA 
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8212 



INPUT CURRENT VS. INPUT VOLTAGE 



OUTPUT CURRENT VS. OUTPUT "LOW" VOLTAGE 
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VS. TEMPERATURE 
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TIMING DIAGRAM 
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A.C. CHARACTERISTICS 

T A = 0°C to + 75°C, V cc = + 5V ± 5% 



Symbol 


Parameter 


Limits 


Unit 




Min. 


Typ. 


Max. 




Ipw 


Pulse Width 


25 


ns 




tpd 


Data To Output Delay 


30 


ns 




twe 


Write Enable To Output Delay 


40 


ns 




IsGt 


Data Setup Time 


15 


ns 




th 


Data Hold Time 


20 


ns 




t' 


Reset To Output Delay 


40 


ns 




ts 


Set To Output Delay 


30 


ns 




te 


Output Enable/Disable Time 


45 


ns 




*c 


Clear To Output Delay 


55 


ns 





CAPACITANCE* 

F = 1 MHz, V BIAS = 2.5V, V cc = +5V, T A = 25°C 



Symbol 


Test 


LIMITS 


Typ. 


Max. 


C|N 


DS, MD Input Capacitance 


9pF 


12 pF 


C|N 


DS 2 , CK, ACK, DI,-DI 8 
Input Capacitance 


5pF 


9pF 


Cqut 


DO,-D0 8 Output Capacitance 


8pF 


12 pF 



"This parameter is sampled and not 100% tested. 



SWITCHING CHARACTERISTICS 

Conditions of Test 

Input Pulse Amplitude = 2.5 V 

Input Rise and Fall Times 5 ns 

Between 1V and 2V Measurements made at 1.5V 

with 15 mA & 30 pF Test Load 



Test Load 

15mA&30pF 



d.u.t.° T 

*30 pF ^=. > l 



INCLUDING JIG & PROBE CAPACITANCE 
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8255A/8255A-5 
PROGRAMMABLE PERIPHERAL INTERFACE 



□ MCS-85™ Compatible 8255A-5 
a 24 Programmable I/O Pins 

a Completely TTL Compatible 

a Fully Compatible with Intel® Micro- 
processor Families 

□ Improved Timing Characteristics 



q Direct Bit Set/Reset Capability Easing 
Control Application Interface 

□ 40-Pin Dual In-Line Package 

□ Reduces System Package Count 

□ Improved DC Driving Capability 



The Intel® 8255A is a general purpose programmable I/O device designed for use with Intel® microprocessors. It has 
24 I/O pins which may be individually programmed in 2 groups of 12 and used in 3 major modes of operation. In the first 
mode (MODE 0), each group of 12 I/O pins may be programmed in sets of 4 to be input or output. In MODE 1, the second 
mode, each group may be programmed to have 8 lines of input or output. Of the remaining 4 pins, 3 are used for hand- 
shaking and interrupt control signals. The third mode of operation (MODE 2) is a bidirectional bus mode which uses 8 
lines for a bidirectional bus, and 5 lines, borrowing one from the other group, for handshaking. 



PIN CONFIGURATION 




PIN NAMES 



D 7 -D 


DATA BUS <BI DIRECTIONAL! 


RESET 


RESET INPUT 


CS 


CHIP SELECT 


RD 


READ INPUT 


WR 


WRITE INPUT 


A0. A1 


PORT ADDRESS 


PA7PA0 


PORT A (BIT) 


'PB7PB0 


PORT B (BIT) 


PC7-PC0 


PORT C (BIT) 


Vcc 


+5 VOLTS 


GND 


a VOLTS 



8255A BLOCK DIAGRAM 



■<c=o 



:i: c 



c=o 



Nl V ,,pp t R 



C^>> 



c=^> 



c 



:>** 



© Intel Corporation, 1978 



February, 1978 
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8255A FUNCTIONAL DESCRIPTION 

General 

The 8255A is a programmable peripheral interface (PPI) 
device designed for use in Intel® microcomputer 
systems. Its function is that of a general purpose I/O 
component to interface peripheral equipment to the 
microcomputer system bus. The functional configura- 
tion of the 8255A is programmed by the system software 
so that normally no external logic is necessary to inter- 
face peripheral devices or structures. 

Data Bus Buffer 

This3-state bidirectional 8-bit buffer is used to interface 
the 8255A to the system data bus. Data is transmitted or 
received by the buffer upon execution of input or output 
instructions by the CPU. Control words and status infor- 
mation are also transferred through the data bus buffer. 



Read/Write and Control Logic 

The function of this block is to manage all of the internal 
and external transfers of both Data and Control or Status 
words. It accepts inputs from the CPU Address and Con- 
trol busses and in turn, issues commands to both of the 
Control Groups. 



(CS) 

Chip Select. A "low" on this input pin enables the com- 
muniction between the 8255A and the CPU. 



(RD) 

Read. A "low" on this input pin enables the 8255A to 
send the data or status information to the CPU on the 
data bus. In essence, it allows the CPU to "read from" 
the 8255A. 

(WR) 

Write. A "low" on this input pin enables the CPU to write 
data or control words into the 8255A. 

(A and A^ 

Port Select and Port Select 1. These input signals, in 
conjunction with the RD and WR inputs, control the 
selection of one of the three ports or the control word 
registers. They are normally connected to the least 
significant bits of the address bus (A and A^. 

8255A BASIC OPERATION 



A1 


A 


RD 


WR 


CS 


INPUT OPERATION (READ) 











1 





PORT A => DATA BUS 





1 





1 





PORT B=» DATA BUS 


1 








1 





PORT C=» DATA BUS 












OUTPUT OPERATION 
(WRITE) 








1 








DATA BUS => PORT A 





1 


1 








DATA BUS => PORT B 


1 





1 








DATA BUS =► PORT C 


1 


1 


1 








DATA BUS ■=» CONTROL 












DISABLE FUNCTION 


X 


X 


X 


X 


1 


DATA BUS=> 3-STATE 


1 


1 





1 





ILLEGAL CONDITION 


X 


X 


1 


1 





DATA BUS =*3-ST ATE 



<".-."-: 



v. - v 



Figure 1. 8255A Block Diagram Showing Data Bus Buffer and Read/Write Control Logic Functions 
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(RESET) 

Reset. A "high on this input clears the control register 
and all ports (A, C, C) are set to the input mode. 

Group A and Group B Controls 

The functional configuration of each port is program- 
med by the systems software. In essence, the CPU "out- 
puts" a control word to the 8255A. The control word con- 
tains information such as "mode", "bit set", "bit reset", 
etc., that initializes the functional configuration of the 
8255. 

Each of the Control blocks (Group A and Group B) accepts 
"commands" from the Read/Write Control Logic, receives 
"control words" from the internal data bus and issues the 
proper commands to its associated ports. 

Control Group A - Port A and Port C upper (C7-C4) 
Control Group B - Port B and Port C lower (C3-C0) 
The Control Word Register can Only be written into. No 
Read operation of the Control Word Register is allowed. 



Ports A, B, and C 

The 8255A contains three 8-bit ports (A, B, and C). All 
can be configured in a wide variety of functional charac- 
teristics by the system software but each has its own 
special features or "personality" to further enhance the 
power and flexibility of the 8255A. 

Port A. One 8-bit data output latch/buffer and one 8-bit 
data input latch. 

Port B. One 8-bit data input/output latch/buffer and one 
8-bit data input buffer. 

Port C. One 8-bit data output latch/buffer and one 8-bit 
data input buffer (no latch for input). This port can be 
divided into two 4-bit ports under the mode control. 
Each 4-bit port contains a 4-bit latch and it can be used 
for the control signal outputs and status signal inputs in 
conjunction with ports A and B. 
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Figure 2. 8225A Block Diagram Showing Group A and 
Group B Control Functions 



PIN CONFIGURATION 




PIN NAMES 



D 7" D J DATA BUS (BIDIRECTIONAL) 


RESET | RESET INPUT 


CS CHIP SELECT 


RD 


READ INPUT 


WR 


WRITE INPUT 


AO, A1 


PORT ADDRESS 


PA7-PA0 


PORT A (BIT) 


PB7PB0 


PORT B (BIT) 


PC7PC0 


PORTC (BIT) 


Vcc 


+5 VOLTS 


GND 


9 VOLTS 
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8255A OPERATIONAL DESCRIPTION 

Mode Selection 

There are three basic modes of operation that can be select- 
ed by the system software: 

Mode — Basic Input/Output 
Mode 1 — Strobed Input/Output 
Mode 2 — Bi-Directional Bus 

When the reset input goes "high" all ports will be set to 
the input mode (i.e., all 24 lines will be in the high im- 
pedance state). After the reset is removed the 8255A can 
remain in the input mode with no additional initialization 
required. During the execution of the system program 
any of the other modes may be selected using a single 
output instruction. This allows a single 8255A to service 
a variety of peripheral devices with a simple software 
maintenance routine. 

The modes for Port A and Port B can be separately defined, 
while Port C is divided into two portions as required by the 
Port A and PortB definitions. All of the output registers, in- 
cluding the status flip-flops, will be reset whenever the 
mode is changed. Modes may be combined so that their 
functional definition can be "tailored" to almost any I/O 
structure. For instance; Group B can be programmed in 
ModeO to monitor simple switch closings or display compu- 
tational results. Group A could be programmed in Mode 1 
to monitor a keyboard or tape reader on an interrupt-driven 
basis. 



CONTROL WORD 



ADDRESS BUS 



CONTROL BUS 



Jt n n 




tJsjw) 'V^/o 5^/o nsQ/c 



PB 7 -PB„ PC 3 -PC PC 7 -PC„ PA 7 -PA„ 



MODE 1 — »T_JL 



TTTJT 



PB 7 -PB CONTROL CONTROL PA,PA„ 

OR I/O OR I/O 



MODE 2 —* f B 



) 8 | I/O 

PB 7 PB I/O I 



£^r 



8 [BI-DIRECTIONAL 
J PA 7 -PA 



D 7 


°6 


°5 


°4 


D 3 


D 2 


°1 


D 








L 


J 




















/ GROUPS \ 




PORT C (LOWER) 
1 =■ INPUT 
= OUTPUT 












PORTB 
1 = INPUT 
= OUTPUT 












MODE SELECTION 
0= MODEO 
1 - MODE 1 
















/ GROUP A \ 




PORT C (UPPER) 
1 = INPUT 
= OUTPUT 












PORTA 
1 = INPUT 
- OUTPUT 












MODE SELECTION 

00 - MODE 

01 -MODE1 
1X = MODE2 
















MODE SET FLAG 
1 = ACTIVE 

































Figure 3. Basic Mode Definitions and Bus Interface 



Figure 4. Mode Definition Format 



The mode definitions and possible mode combinations 
may seem confusing at first but after a cursory review of 
the complete device operation a simple, logical I/O ap- 
proach will surface. The design of the 8255A has taken 
into account things such as efficient PC board layout, 
control signal definition vs PC layout and complete 
functional flexibility to support almost any peripheral 
device with no external logic. Such design represents 
the maximum use of the available pins. 



Single Bit Set/Reset Feature 

Any of the eight bits of Port C can be Set or Reset using a 
single OUTput instruction. This feature reduces software 
requirements in Control-based applications. 



7-42 



8255A/8255A-5 



CONTROL WORD 



D 7 D 6 D 5 D 4 D 3 D 2 D, D 



XXX 



DON'T 
CARE 



BIT SET/RESET 

1-SET 

- RESET 



BIT SET/RESET FLAG 
= ACTIVE 



Figure 5. Bit Set/Reset Format 



When Port C is being used as status/control for Port A or B, 
these bits can be set or reset by using the Bit Set/Reset op- 
eration just as if they were data output ports. 

Interrupt Control Functions 

When the 8255A is programmed to operate in mode 1 or 
mode 2, control signals are provided that can be used as 
interrupt request inputs to the CPU. The interrupt re- 
quest signals, generated from port C, can be inhibited or 
enabled by setting or resetting the associated INTE flip- 
flop, using the bit set/reset function of port C. 

This function allows the Programmer to disallow or allow a 
specific I/O device to interrupt the CPU without affecting 
any other device in the interrupt structure. 

INTE flip-flop definition: 

(BIT-SET) - INTE is SET - Interrupt enable 
(BIT-RESET) - INTE is RESET - Interrupt disable 

Note: All Mask flip-flops are automatically reset during 
mode selection and device Reset. 



Operating Modes 



MODE (Basic Input/Output). This functional configura- 
tion provides simple input and output operations for 
each of the three ports. No "handshaking" is required, 
data is simply written to or read from a specified port. 



Mode Basic Functional Definitions: 

• Two 8-bit ports and two 4-bit ports. 

• Any port can be input or output. 

• Outputs are latched. 

• Inputs are not latched. 

o 16 different Input/Output configurations are possible 
in this Mode. 



\ 



X 



x 



j c 



■( 



>: 



K 



X 



1 — 



MODE (Basic Input) 



\ 



X 



-•ww- 



J c 



X 



-*WD- 
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K 



D( 



-•WB- 



MODE (Basic Output) 
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MODE Port Definition 



A 


B 


GROUP A 




GROUP B 


D 4 


D 3 


Dl 


DO 


PORTA 


PORTC 
(UPPER) 


# 


PORTB 


PORTC 
(LOWER) 














OUTPUT 


OUTPUT 





OUTPUT 


OUTPUT 











1 


OUTPUT 


OUTPUT 


1 


OUTPUT 


INPUT 








1 





OUTPUT 


OUTPUT 


2 


INPUT 


OUTPUT 








1 


1 


OUTPUT 


OUTPUT 


3 


INPUT 


INPUT 





1 








OUTPUT 


INPUT 


4 


OUTPUT 


OUTPUT 





1 





1 


OUTPUT 


INPUT 


5 


OUTPUT 


INPUT 





1 


1 





OUTPUT 


INPUT 


6 


INPUT 


OUTPUT 





1 


1 


1 


OUTPUT 


INPUT 


7 


INPUT 


INPUT 













INPUT 


OUTPUT 


8 


OUTPUT 


OUTPUT 










1 


INPUT 


OUTPUT 


9 


OUTPUT 


INPUT 







1 





INPUT 


OUTPUT 


10 


INPUT 


OUTPUT 







1 


1 


INPUT 


OUTPUT 


11 


INPUT 


INPUT 




1 








INPUT 


INPUT 


12 


OUTPUT 


OUTPUT 




1 





1 


INPUT 


INPUT 


13 


OUTPUT 


INPUT 




1 


1 





INPUT 


INPUT 


14 


INPUT 


OUTPUT 




1 


1 


1 


INPUT 


INPUT 


15 


INPUT 


INPUT 



MODE Configurations 



CONTROL WORD #0 

°7 D 6 D 5 D 4 D 3 D 2 D 1 D 








-f± PA 7 .PA„ 



/i *■ PC r PC 4 



/ pc 3 -pc 



+ -PB 7 .PB 



CONTROL WORD #2 
D 7 D G D 5 D 4 


°3 


D 2 


Dl 


°0 


1 

















1 






-/ " PAj-PA,, 

-^ PC 7 -PC 4 

-/■* — ► pc 3 -pc 

-Z 1 PB 7 PB 



CONTROL WORD #1 
°7 Dr D s D. D, D, D. D„ 



CONTROL WORD #3 











-/■ PAj-PA,, 



-/■ ► PC7-PC 4 



-/-* PC 3 .PC 

-7^ PB 7 PB 



-/■ ► PAj-PA,, 

-/^ — " p C 7 PC 4 

-Z 1 p c 3 p c 

"7^ p B7 p B 
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CONTROL WORD #4 



D 7 D 6 D 5 D 4 D 3 D 2 D, D 
10 10 



/ - PAjPA,, 



-P- PC 7 PC 4 




-/■ pc 3 -pc 



/ PB 7 -PB 



CONTROL WORD #8 



D 7 D 6 D 5 D 4 D 3 D 2 D, D, 
10 10 



/5 PA 7 -P, 



/ 4 
■/- 1 - PC 7 PC, 




-f pc 3 -pc 



-/■ " PB 7 -PB 



CONTROL WORD #5 
D 7 D 6 D 5 D 4 D 3 D 2 D, D„ 



CONTROL WORD #9 



10 



D 7 D 6 D 5 D 4 D 3 D 2 D, D 
10 10 1 




■/ - PA 7 -PAo 



-P- PC 7 -PC 4 



■Z 1 pc 3 -pc 



-/- " PB 7 PB 




-/■ P/yPA,, 



/ - PC 7 -PC 4 



/ pc 3 -pc 



-f - PB 7 -PB 



CONTROL WORD #6 



D 7 D 6 D 5 D 4 D 3 D 2 D, D, 
10 10 10 



CONTROL WORD #10 
D 7 D 6 D 5 D 4 D 3 D 2 D, D 



10 10 




7^ ► PA 7 PAq 



■/-$■ PC 7 -PC 4 



■P- — - pc 3 -pc 



-f PB 7 PB 




/ PA 7 PA 



-/- ► PC 7 PC 4 



*■ »- PC,PC n 



/ PB 7 PB 



CONTROL WORD #7 



CONTROL WORD #11 



D 7 D 6 D 5 D 4 D 3 D 2 D 1 D 
10 10 11 



D 7 D 6 D 5 D 4 D 3 D 2 D, D 
10 10 11 




T PA 7 PA„ 

7^ PCj-PC 4 



-/■ PA 7 PA„ 



■P- pc 3 pc 



/ PB 7 PB 




7^ PB 7 -PB 
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CONTROL WORD #12 



D 7 D 6 D 5 D 4 D 3 D; D, D 
10 110 




-/■ PA 7 -PA„ 



-/- PC 7 -PC 4 



-P- » PC 3 -PC 



■/■ PB 7 PB 



CONTROL WORD #14 
D 7 D 6 D 5 D 4 D 3 D 2 D, D„ 



110 10 




-/- PA 7 -PA„ 



7^ PC 3 -PC 



7* PB 7 PB 



CONTROL WORD #13 



D 7 D„ D 5 D„ D 3 D 2 D, D„ 
10 110 1 



CONTROL WORD #15 

D 7 D 6 D 5 D 4 D 3 D 2 D 1 D 



110 



■/■ PA 7 -PA„ 



r / PC 7 -PC 4 




-P PC 3 -PC„ 



■/ ► PB r PB 




-/■ PB 7 PB 



Operating Modes 



MODE 1 (Strobed Input/Output). This functional con- 
figuration provides a means for transferring I/O data to 
or from a specified port in conjunction with strobes or 
"handshaking" signals. In mode 1, port A and Port B use 
the lines on port C to generate or accept these "hand- 
shaking" signals. 



Mode 1 Basic Functional Definitions: 

• Two Groups (Group A and Group B) 

• Each group contains one 8-bit data port and one 4-bit 
control/data port. 

• The 8-bit data port can be either input or output. 
Both inputs and outputs are latched. 

• The 4-bit port is used for control and status of the 
8-bit data port. 
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Input Control Signal Definition 

STB (Strobe Input). A "low" on this input loads data into 
the input latch. 

IBF (Input Buffer Full F/F) 

A "high" on this output indicates that the data has been 
loaded into the input latch; in essence, an acknowledgement 
IBF is set by STB input being low and is reset by the rising 
edge of the RD input. 

INTR (Interrupt Request) 

A "high" on this output can be used to interrupt the CPU 
when an input device is requesting service. INTR is set by 
the STB is a "one", IBF is a "one" and INTE is a "one". 
It is reset by the falling edge of RD. This procedure allows 
an input device to request service from the CPU by simply 
strobing its data into the port. 



INTE A 

Controlled by bit set/reset of PC 4 . 

INTEB 

Controlled by bit set/reset of PC2. 



MODE 1 (PORT A) 



CONTROL WORD 
D 7 D 6 D 5 D 4 D 3 D 2 D, D„ 



10 11 1/0 



RIXM 

PC 6.7 
L*- 1 = INPUT 



PA 7 -PA 


Oa 


' H PC 3 


► 


PC 6 . 7 


2 



CONTROL WORD 
D 7 D 6 D 5 P„ D 3 D 2 D, D 



MODE 1 (PORT B) 




PB 7 -PB 


<^ 


r -| 
I INTE I 


PC ? 


4 




PC, 


m 


1 


pc 


— - 



» INTRb 



Figure 6. MODE 1 Input 




INPUT FROM 

PERIPHERAL 



Figure 7. MODE 1 (Strobed Input) 
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Output Control Signal Definition 



OBF (Output Buffer Full F/F). The OBF output will go 
"low" to indicate that the CPU has written data out to 
the specified port. The OBF F/F will be set by the rising 
edge of the WR input and reset by ACK Input being low. 

ACK (Acknowledge Input). A "low" on this input informs 
the 8255A that the data from port A or port B has been ac- 
cepted. In essence, a response from the peripheral 
device indicating that it has received the data output by 
the CPU. 



INTR (Interrupt Request). A "high" on this output can be 
used to interrupt the CPU when an output device has ac- 
cepted data transmitted by the CPU. INTR is set when 
ACK is a "one", OBF is a "one" and INTE is a "one". It is 
reset by the falling edge of WR. 



INTE A 

Controlled by bit set/reset of PC 6- 

INTEB 

Controlled by bit set/reset of PC 2- 





MODE1 (PORTA) 




CONTROL WORD 




PA 7 -PA„ 


x> 


D 7 D 6 D 5 D 4 D 3 D 2 D 1 D 




PC 7 




hhhl'MXIXIXI 


I 1 

I INTE I 
I A I 


►OBF A 


PC 4.5 


pc 6 





"* ■ ACK A 


= OUTPUT 


■'Li 








Li> 


PC 3 






*■ INTR A 


wn n 










pc 4 .5 


2 




MODE1 (PORTB) 




CONTROL WORD 




PB 7 -PB 


^> 






PC, 




hDxKM^'l-lXI 


r "i 

1 INTE 1 
1 B 1 


-OBF B 




PC 2 











Li 








LO 


PC 






iNTn B 


— 





















Figure 8. MODE 1 Output 




Figure 9. Mode 1 (Strobed Output) 
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Combinations of MODE 1 

Port A and Port B can be individually defined as input or 
output in Mode 1 to support a wide variety of strobed I/O 
applications. 



CONTROL WORD 
°7 °6 D 5 D 4 


D 3 


D 2 D, D 


I 1 


loli 


1 


1/0 


H-M 








L 


PC 6.7 
"■ 1 - INPUT 
- OUTPUT 



PA 7 PA„ 



<& 



-/—• I/O 



^> 



PORT A - (STROBED INPUT) 
PORT B - (STROBED OUTPUT) 



-OBF B 
•ACK B 
-INTR, 




PORT A - (STROBED OUTPUT) 
PORT B - (STROBED INPUT) 



Figure 10. Combinations of MODE 1 



Operating Modes 



Output Operations 



MODE 2 (Strobed Bidirectional Bus I/O). This functional 
configuration provides a means for communicating with 
a peripheral device or structure on a single 8-bit bus for 
both transmitting and receiving data (bidirectional bus 
I/O). "Handshaking" signals are provided to maintain 
proper bus flow discipline in a similar manner to MODE 
1. Interrupt generation and enable/disable functions are 
also available. 



OBF (Output Buffer Ful). The OBF output will go "low" 
to indicate that the CPU has written data out to port A. 

ACK (Acknowledge). A "low" on this input enables the 
tri-state output buffer of port A to send out the data. 
Otherwise, the output buffer will. be-4n the high im- 
pedance state. 



MODE 2 Basic Functional Definitions: 
© Used in Group A only . 

» One 8-bit, bi-directional bus Port (Port A) and a 5-bit 
control Port (PortC). 

• Both inputs and outputs are latched. 

• The 5-bit control port (Port C) is used for control 
and status for the 8-bit, bi-directional bus port (Port 
A). 

Bidirectional Bus I/O Control Signal Definition 

INTR (Interrupt Request). A high on this output can be 
used to interrupt the CPU for both input or output opera- 
tions. 



INTE 1 (The INTE Flip-Flop Associated with OBF). Con- 
trolled by bit set/reset of PC 6 . 

Input Operations 

STB (Strobe Input) 

STB (Strobe Input). A "low" on this input loads data into 
the input latch. 

IBF (Input Buffer Full F/F). A "high" on this output in- 
dicates that data has been loaded into the input latch. 



INTE 2 (The INTE Flip-Flop Associated with IBF). Con- 
trolled by bit set/reset of PC 4 . 
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CONTROL WORD 
D 7 D 6 D 5 D 4 D 3 D 2 D, D„ 



M 



1 - INPUT 
■= OUTPUT 



■ PORT B 
1 = INPUT 
- OUTPUT 



GROUP B MODE 

- MODE 

1 = MODE 1 




■f ►I/O 



Figure 11. MODE Control Word 



Figure 12. MODE 2 



DATA FROM 
CPU TO 8255A 



PERIPHERAL 
BUS 




DATA FROM 
PERIPHERAL TO 825SA 



DATA FROM 
8255A TO PERIPHERAL 



DATA FROM 
8255A TO 8080 



Figure 13. MODE 2 (Bidirectional) 



NOTE: Any sequence where WR occurs before ACK and STB occurs before RD is permissible. 
(INTR - IBF • MASK • STB • RD + OBF • MASK • ACK • WR ) 
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MODE 2 AND MODE (INPUT) 





MODE 2 AND MODE (OUTPUT) 



MODE 2 AND MODE 1 (OUTPUT) 



MODE 2 AND MODE 1 (INPUT) 



CONTROL WORD 
°7 D 6 D 5 D 4 D 3 °2 D 1 D 

hHXIXIXH°IXl 







PAj-PAo 

pc 7 

PC 6 


<^> 


pc 4 

PC 5 
PB 7 PB 

PC, 
PC 2 


K 


8 > 


V 


PC 


► 



OBF A 
ACK. 



CONTROL WORD 
D 7 D 6 D 5 D 4 D 3 D 2 D, D 



PAjPA,, 



CO 



c^ 



■stbb 

IBF B 



Figure 14. MODE 2 Combinations 
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Mode Definition Summary 





MODEO 




IN 


OUT 


PA 


IN 


OUT 


PAt 


IN 


OUT 


PA 2 


IN 


OUT 


PA 3 


IN 


OUT 


PA4 


IN 


OUT 


PA5 


IN 


OUT 


PA 6 


IN 


OUT 


PA7 


IN 


OUT 


PB 


IN 


OUT 


PB! 


IN 


OUT 


PB2 


IN 


OUT 


PB3 


IN 


OUT 


PB4 


IN 


OUT 


PB5 


IN 


OUT 


PB 6 


IN 


OUT 


PB 7 


IN 


OUT 


PC 


IN 


OUT 


PC! 


IN 


OUT 


PC 2 


IN 


OUT 


PC 3 


IN 


OUT 


PC4 


IN 


OUT 


PC 5 


IN 


OUT 


pc 6 


IN 


OUT 


PC? 


IN 


OUT 



MODE 1 


IN 


OUT 


IN 
IN 
IN 
IN 
IN 
IN 
IN 
IN 


OUT 
OUT 
OUT 
OUT 
OUT 
OUT 
OUT 
OUT 


IN 
IN 
IN 
IN 
IN 
IN 
IN 
IN 


OUT 
OUT 
OUT 
OUT 
OUT 
OUT 
OUT 
OUT 


INTR B 

ibf b 

STB B 
INTR A 
STB A 

ibf a 

I/O 
I/O 


INTR B 
OBF B 

ack b 

INTRa 

I/O 

I/O 
ACK A 

obf a 



MODE 2 



GROUP A ONLY 



I/O 

I/O 

I/O 
INTRa 
STB A 
IBF A 
ACK A 

obf a 



MODEO 
\- OR MODE 1 
ONLY 



Special Mode Combination Considerations 

There are several combinations of modes when not all of the 
bits in Port C are used for control or status. The remaining 
bits can be used as follows: 

If Programmed as Inputs — 

All input lines can be accessed during a normal Port C 

read. 

If Programmed as Outputs — 

Bits in C upper (PC7-PC4) must be individually accessed 

using the bit set/reset function. 

Bits in C lower (PC3-PC0) can be accessed using the bit 
set/reset function or accessed as a threesome by writing 
into Port C. 

Source Current Capability on Port B and Port C 

Any set of eight output buffers, selected randomly from 
Ports B and C can source 1mA at 1.5 volts. This feature 
allows the 8255 to directly drive Darlington type drivers 
and high-voltage displays that require such source current. 

Reading Port C Status 

In Mode 0, Port C transfers data to or from the peripheral 
device. When the 8255 is programmed to function in Modes 
1 or 2, Port C generates or accepts "hand-shaking" signals 
with the peripheral device. Reading the contents of Port C 



allows the programmer to test or verify the "status" of each 
peripheral device and change the program flow accordingly. 

There is no special instruction to read the status informa- 
tion from Port C. A normal read operation of Port C is 
executed to perform this function. 





INPUT CONFIGURATION 
D 7 D 6 D 5 D 4 D 3 D 2 D, D 






I/O 


I/O 


IBF A 


INTE A 


INTR A 


inte b 


IBF B 


intr b 










GROUP A GROUP B 

OUTPUT CONFIGURATION 
D 7 D 6 D 5 D„ D 3 D 2 D, D 




OBF A 


INTE A 


I/O 


I/O 


intrJ inte b 


OBF B 


INTR B 










GROUP A GROUPS 


Figure 15. MODE 1 Status Word Format 




D 7 D 6 D 5 D 4 D 3 D 2 D, D„ 






6bf a 


INTE, 


IBF A 


INTE 2 


INTR A 


X 


X 


X 










GROUP A ^^__— GROUP B 
(DEFINED BY MODE OR MODE 1 SELECTION) 



Figure 16. MODE 2 Status Word Format 
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APPLICATIONS OF THE 8255A 

The 8255A is a very powerful tool for interfacing 
peripheral equipment to the microcomputer system. It 
represents the optimum use of available pins and is flex- 
ible enough to interface almost any I/O device without 
the need for additional external logic. 

Each peripheral device in a microcomputer system 
usually has a "service routine" associated with it. The 
routine manages the software interface between the 
device and the CPU. The functional definition of the 
8255A is programmed by the I/O service routine and 
becomes an extension of the system software. By ex- 
amining the I/O devices interface characteristics for 
both data transfer and timing, and matching this infor- 
mation to the examples and tables in the detailed opera- 
tional description, a control word can easily be devel- 
oped to initialize the 8255A to exactly "fit" the applica- 
tion. Figures 17 through 23 present a few examples of 
typical applications of the 8255A. 



INTERRUPT 
REQUEST 



INTERRUPT 
REQUEST " 



MODE1 
(OUTPUT) 



MODE1 
(OUTPUT) 



DATA READY 
ACK 

PAPER FEED 
FORWARD/REV 



DATA READY 
ACK 



HIGH-SPEED 
PRINTER 



HAMMER 
RELAYS 



DATA READY 

ACK 

PAPER FEED 

FORWARD/REV 

RIBBON 

CARRIAGE SEN. 



INTERRUPT^ 
REQUEST 



CONTROL LOGIC AND DRIVERS 



Figure 17. Printer Interface 



PC 3 
8255A 

MODE 1 , 
(INPUT) 


PAq 
PA, 
PA 2 
PA 3 
PA 4 
PA 5 

p A 6 
PA 7 

pc 4 
_pc 5 




R i 

R 2 FULLY 
R DECODED 
3 KEYBOARD 
R 4 
R 5 

SHIFT 
CONTROL 

STROBE 
ACK 




























MODE 1 
(OUTPUT) 

p C 


PB, 
PB 2 
PB 3 
PB 4 
p B 5 
p B 6 
PB 7 

PC, 
PC 2 

p c 6 

-PC 7 




Bo 

B 1 

R BURROUGHS 
2 SELF-SCAN 
B 3 DISPLAY 

B* 

B 5 

BACKSPACE 

CLEAR 

DATA READY 
ACK 

BLANKING 
CANCEL WORD 



























INTERRUPT 
REQUEST 



Figure 18. Keyboard and Display Interface 



INTERRUPT 
REQUEST 



PC 3 


rpA,, 

PA, 
PA 2 










R o 

R 1 

R 2 










MODE 1 


PA 3 




R FULLY 

3 DECODED 




(INPUT) 


PA 4 





R KEYBOARD 




PA 5 





R 5 


8255A 


PA 6 




SHIFT 






PA 7 




CONTROL 






PC 4 




STROBE 


- 




pc 5 


_ 


ACKNOWLEDGE 




^6 

[ p c 7 


- 


BUSY LT 
TEST LT 












p Bo 














PB, 
PB 2 
p B 3 






















MODE 










p B 4 
PB, 
























PB fi 
















PB-, 




<f ~t> 































TERMINAL 
ADDRESS 



Figure 19. Keyboard and Terminal Address Interface 
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INTERRUPT 
REQUEST 



MODE 
(OUTPUT) 



BIT 
SET/RESET 



MODE 
(INPUT) 



12-BIT 

DA 

CONVERTER 

(DAC) 



STB DATA 
OUTPUT EN 



SAMPLE EN 
STB 



LSB 

8-BIT 

AD 

CONVERTER 

(ADC) 



ANALOG OUTPUT 



■ ANALOG INPUT 



p c 3 


PA 
PA, 
PA 2 






Do 
°2 




















PA 3 
PA 4 
PA 5 






D, FLOPPY DISK 
CONTROLLER 
D 4 AND DRIVE 
° 5 








^ 


^ 


MODE 2 - 


PA 6 






D 6 








PA 7 
PC 4 






D 7 

DATA STB 














^5 
PC 7 






ACK (IN) 
DATA READY 












p c 6 






ACK (OUT) 






8255A 
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Figure 20. Digital to Analog, Analog to Digital 



Figure 22. Basic Floppy Disc Interface 



INTERRUPT 
REQUEST 



■r pA o 

I PA, 



MODE 1 
(OUTPUT)" 



MODE . 
(OUTPUT) 



CRT CONTROLLER 

• CHARACTER GEN. 

• REFRESH BUFFER 

• CURSOR CONTROL 



SHIFT 
CONTROL 

DATA READY 
ACK 

BLANKED 
BLACK/WHITE 



ROW STB 
COLUMN STB 
CURSOR H/V STB 



CURSOR/ROW/COLUMN 

ADDRESS 

H& V 



MODE 1 
(INPUT) 



MODE 
(INPUT) 



MODE 
(OUTPUT) 



8 LEVEL 
PAPER 
TAPE 

READER 



STB 
ACK 
STOP/GO 



MACHINE TOOL 



START/STOP 

LIMIT SENSOR (H/V) 

OUT OF FLUID 



CHANGE TOOL 

LEFT/RIGHT 

UP/DOWN 

HOR. STEP STROBE 

VERT. STEP STROBE 

SLEW/STEP 

FLUID ENABLE 

EMERGENCY STOP 



Figure 21. Basic CRT Controller Interface 



Figure 23. Machine Tool Controller Interface 



8255 A/8255 A-5 



ABSOLUTE MAXIMUM RATINGS* 



Ambient Temperature Under Bias C to 70 C 

Storage Temperature —65 C to +150 C 

Voltage on Any Pin 

With Respect to Ground -0.5V to +7V 

Power Dissipation 1 Watt 



*COMMENT: Stresses above those listed under "Absolute 
Maximum Ratings" may cause permanent damage to the 
device. This is a stress rating only and functional opera- 
tion of the device at these or any other conditions above 
those indicated in the operational sections of this specifi- 
cation is not implied. Exposure to absolute maximum 
rating conditions for extended periods may affect device 
reliability. 



D.C. CHARACTERISTICS 

T A = 0°C to 70°C, V cc = +5V +5%; GND = 0V 



SYMBOL 


PARAMETER 


MIN. 


MAX. 


UNIT 


TEST CONDITIONS 


V|L 


Input Low Voltage 


-0.5 


0.8 


V 




V| H 


Input High Voltage 


2.0 


v C c 


V 




Vol (DB) 


Output Low Voltage (Data Bus) 




0.45 


V 


Iol = 2.5mA 


Vol(PER) 


Output Low Voltage (Peripheral Port) 




0.45 


V 


Iol = 1.7mA 


Voh(DB) 


Output High Voltage (Data Bus) 


2.4 




V 


Ioh = -400mA 


Voh(peR) 


Output High Voltage (Peripheral Port) 


2.4 




V 


Ioh = -200mA 


IdarI 1 ' 


Darlington Drive Current 


-1.0 


-4.0 


mA 


Rext . = 75012; V EXT = 1.5V 


•cc 


Power Supply Current 




120 


mA 




IlL 


Input Load Current 




±10 


HA 


V| N = Vcc to 0V 


>OFL 


Output Float Leakage 




+ 10 


jixA 


Vqut = V cc to0V 



Note 1 : Available on any 8 pins from Port B and C. 

CAPACITANCE 

T A =25°C; V cc = GND = 0V 



SYMBOL 


PARAMETER 


MIN. 


TYP. 


MAX. 


UNIT 


TEST CONDITIONS 


C IN 


Input Capacitance 






10 


pF 


fc= 1MHz 


C l/0 


I/O Capacitance 






20 


pF 


Unmeasured pins returned to GND 






750S! 

-Wv o v EXT * 



100pF 



*Vext is set a ' various voltages during testing to guarantee the specification. 



Figure 24. Test Load Circuit (for dB) 
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A.C. CHARACTERISTICS 

T A = 0°C to 70°C; V CC = +5V ±5%; GND = OV 

Bus Parameters 
Read: 



NOTE- 
The 8255A-5 specifica- 
tions are not final. Some 
parametric limits are sub- 
ject to change. 





PARAMETER 


8255A 


8255A-5 




SYMBOL 


MIN. 


MAX. 


MIN. 


MAX. 


UNIT 


*AR 


Address Stable Before READ 












ns 


tRA 


Address Stable After READ 












ns 


tRR 


READ Pulse Width 


300 




300 




ns 


tRD 


Data Valid From READ! 1 ! 




250 




200 


ns 


tDF 


Data Float After READ 


10 


150 


10 


100 


ns 


tRV 


Time Between READs and/or WR ITEs 


850 




850 




ns 


Write: 




PARAMETER 


8255A 


8255A-5 




SYMBOL 


MIN. 


MAX. 


MIN. 


MAX. 


UNIT 


*AW 


Address Stable Before WR ITE 












ns 


*WA 


Address Stable After WRITE 


20 




20 




ns 


t W W 


WRITE Pulse Width 


400 




300 




ns 


*DW 


Data Valid to WRITE (T.E.) 


100 




100 




ns 


tWD 


Data Valid After WRITE 


30 




30 




ns 


Other Timings: 




PARAMETER 


8255A 


8255A-5 




SYMBOL 


MIN. 


MAX. 


MIN. 


MAX. 


UNIT 


%B 


WR = 1 to Output' 1 ] 




350 




350 


ns 


t|R 


Peripheral Data Before RD 












ns 


tHR 


Peripheral Data After RD 












ns 


tAK 


ACK Pulse Width 


300 




300 




ns 


tST 


STB Pulse Width 


500 




500 




ns 


tps 


Per. Data Before T.E. of STB 












ns 


tPH 


Per. Data After T.E. of STB 


180 




180 




ns 


tAD 


ACK = to Output! 1 ! 




300 




300 


ns 


tKD 


ACK= 1 to Output Float 


20 


250 


20 


250 


ns 


*WOB 


WR = 1 toOBF = 0l 1 l 




650 




650 


ns 


tAOB 


ACK = 0toOBF = l[ 1 ] 




350 




350 


ns 


tsiB 


STB = to IBF = If] 




300 




300 


ns 


tRIB 


RD = 1 to IBF = 0[ 1 1 




300 




300 


ns 


tRIT 


RD = 0to INTR = 0l 1 ] 




400 




400 


ns 


tSIT 


STB = 1 to INTR = 1[ 1 1 




300 




300 


ns 


l AIT 


ACK= 1 to INTR = 1H] 




350 




350 


ns 


%IT 


WR = 0to INTR = Of 1 1 




850 




850 


ns 



Notes: 1. Test Conditions: 8255A: Cl = 100pF; 8255A-5: C|_ = 150pF. 

2. Period of Reset pulse must be at least 50ms during or after power on. 
Subsequent Reset pulse can be 500 ns min. 
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X2-0^ ^*, 2.0 \/~ 

J^ TEST POINTS Y 

08 ^ "- 08 /V 



Figure 25. Input Waveforms for A.C. Tests 
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Figure 26. MODE (Basic Input) 
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Figure 27. MODE (Basic Output) 
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INPUT FROM 
PERIPHERAL 




Figure 28. MODE 1 (Strobed Inut) 
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Figure 29. MODE 1 (Strobed Output) 
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PERIPHERAL 
BUS 



DATA FROM 
' 8080 TO 8255 




DATA FROM 
PERIPHERAL TO 8255 



DATA FROM 
8255 TO PERIPHERAL 



DATA FROM 
8255 TO 8080 



Figure 30. MODE 2 (Bidirectional) 



NOTE: Any sequence where WR occurs before ACK and STB occurs before RD is permissible. 
(INTR= IBF • MASK • STB • RD+OBF • MASK • ACK • WR ) 
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8251A 
PROGRAMMABLE COMMUNICATION INTERFACE 



□ Synchronous and Asynchronous 
Operation 

si Synchronous 5-8 Bit Characters; 
Internal or External Character Synchro- 
nization; Automatic Sync Insertion 

□ Asynchronous 5-8 Bit Characters; 
Clock Rate— 1, 16 or 64 Times Baud 
Rate; Break Character Generation; 1, 
1 1 /2, or 2 Stop Bits; False Start Bit 
Detection; Automatic Break Detect 
and Handling; 19.2K Baud. 

□ Baud Rate — DC to 64K Baud 

□ Full Duplex, Double Buffered, Trans- 
mitter and Receiver 

The Intel® 8251A is the enhanced version of the industry standard, Intel® 8251 Universal Synchronous/Asynchronous 
Receiver/Transmitter (USART), designed for data communications with Intel's new high performance family of 
microprocessors such as the 8085. The 8251 A is used as a peripheral device and is programmed by the CPU to operate 
using virtually any serial data transmission technique presently in use (including IBM "bi-sync"). The USART accepts 
data characters from the CPU in parallel format and then converts them into a continuous serial data stream for 
transmission. Simultaneously, it can receive serial data streams and convert them into parallel data characters for the 
CPU. The USART will signal the CPU whenever it can accept a new character for transmission or whenever it has 
received a character for the CPU. The CPU can read the complete status of the USART at any time. These include data 
transmission errors and control signals such as SYNDET, TxEMPTY. The chip is constructed using N-channel silicon 
gate technology. 



a Error Detection — Parity, Overrun and 
Framing 

q Fully Compatible with 8080/8085 CPU 

a 28-Pin DIP Package 

□ All Inputs and Outputs are TTL 
Compatible 

a Single +5V Supply 

a Single TTL Clock 



PIN CONFIGURATION 



D? 3 
d 3 c: 



FUD | 
GND I 



7 8251 A 22 




PIN NAMES 



D, D 


Data Bus (8 bus) 




C/D 


Control or Data is to be Wntte 


n or Read 


RD 


Read Data Command 




WR 


Write Data or Control Comma 


nd 


cs 


Chip Enable 




CLK 


Clock Pulse ITTLI 




RESET 


Reset 




TxC 


Transmitter Clock 




TxD 


Transmitter Data 




RxC 


Receiver Clock 




RxD 


Receiver Data 




RxRDY 


Receiver Ready (has character 


tor 8080) 


TxRDY 


Transmitter Ready (ready tor 


char, from 8080) 



DSR 


Data Set Ready 


DTR 


Data Terminal Ready 


SYNDET/BD 


Sync Detect/ 
Break Detect 


RTS 


Request to Send Data 


CTS 


Clear to Send Data 


TxE 


Transmitter Empty 


Vcc 


+5 Volt Supply 


GND 


Ground 



BLOCK DIAGRAM 



RESET. 
CLK. 
C/D. 



-\ 


DATA 
BUS 


-1/ 


BUF 


FER 


„ 








READ/WRITE 


— >. 


CONTROL 


— »-o 


LOGIC 


— »-o 





<p 



DSR- 
DTR. 



CTS- 
RTS . 



MODEM 
CONTROL 



TRANSMIT 

BUFFER 

(P-S) 



RECEIVE 
CONTROL 



.TxRDY. 

.TxE 

-TxC 



R«RDY 
» R«C 
»» SYNDET 



© Intel Corporation, 1978 



February, 1978 
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FEATURES AND ENHANCEMENTS 

8251 A is an advanced design of the industry stan- 
dard USART, the Intel® 8251. The 8251A oper- 
ates with an extended range of Intel micropro- 
cessors that includes the new 8085 CPU and main- 
tains compatibility with the 8251. Familiarization 
time is minimal because of compatibility and 
involves only knowing the additional features and 
enhancements, and reviewing the AC and DC speci- 
fications of the 8251A. 

The 8251 A incorporates all the key features of 
the 8251 and has the following additional features 
and enhancements: 

• 8251 A has double-buffered data paths with 
separate I/O registers for control, status. 
Data In, and Data Out, which considerably 
simplifies control programming and mini- 
mizes CPU overhead. 

• In asynchronous operations, the Receiver 
detects and handles "break" automatically, 
relieving the CPU of this task. 

• A refined Rx initialization prevents the 
Receiver from starting when in "break" 
state, preventing unwanted interrupts from 
a disconnected USART. 

© At the conclusion of a transmission, TxD 
line will always return to the marking state 
unless SBRK is programmed. 



• Tx Enable logic enhancement prevents a 
Tx Disable command from halting trans- 
mission until all data previously written has 
been transmitted. The logic also prevents 
the transmitter from turning off in the middle 
of a word. 

© When External Sync Detect is programmed. 
Internal Sync Detect is disabled, and an Ex- 
ternal Sync Detect status is provided via a 
flip-flop which clears itself upon a status read. 

© Possibility of false sync detect is minimized 
by ensuring that if double character sync is 
programmed, the characters be contiguously 
detected and also by clearing the Rx register 
to all ones whenever Enter Hunt command is 
issued in Sync mode. 

• As_ long_as_ the 8251 A is not selected, the 
RD and WR do not affect the internal opera- 
tion of the device. 

• The 8251 A Status can be read at any time 
but the status update will be inhibited during 
status read. 

o The 8251A is free from extraneous glitches 
and has enhanced AC and DC characteristics, 
providing higher speed and better operating 
margins. 

© Baud rate from DC to 64K. 

o Fully compatible with Intel's new industry 
standard, the MCS-85. 
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8251A BASIC FUNCTIONAL DESCRIPTION C/D (Control/Data) 



General 

The 8251 A is a Universal Synchronous/Asynchronous Re- 
ceiver/Transmitter designed specifically for the 80/85 Micro- 
computer Systems. Like other I/O devices in a Microcom- 
puter System, its functional configuration is programmed 
by the system's software for maximum flexibility. The 
8251 A can support virtually any serial data technique cur- 
rently in use including bi-sync. 

In a communication environment an interface device must 
convert parallel format system data into serial format for 
transmission and convert incoming serial format data into 
parallel system data for reception. The interface device must 
also delete or insert bits or characters that are functionally 
unique to the communication technique. In essence, the 
interface should appear "transparent" to the CPU, a simple 
input or output of byte-oriented system data. 

Data Bus Buffer 

This 3-state, bidirectional, 8-bit buffer is used to interface 
the 8251 A to the system Data Bus. Data is transmitted or 
received by the buffer upon execution of INput or OUTput 
instructions of the CPU. Control words, Command words 
and Status information are also transferred through the 
Data Bus Buffer. The command status and data in, and 
data out are separate 8-bit registers to provide double 
buffering. 

This functional block accepts inputs from the system Con- 
trol bus and generates control signals for overall device 
operation. It contains the Control Word Register and Com- 
mand Word Register that store the various control formats 
for the device functional definition. 

RESET (Reset) 

A "high" on this input forces the 8251A into an "Idle" 
mode. The device will remain at "Idle" until a new set of 
control words is written into the 8251A to program its 
functional definition. Minimum RESET pulse width is 
6 tcv (clock must be running). 

CLK (Clock) 

The CLK input is used to generate internal device timing 
and is normally connected to the Phase 2 (TTL) output of 
the 8224 Clock Generator. No external inputs or outputs 
are referenced to CLK but the frequency of CLK must be 
greater than 30 times the Receiver or Transmitter data 
bit rates. 



This input, in conjunction with the WR and RD inputs, 
informs the 8251 A that the word on the Data Bus is either 
a data character, control word or status information. 
1 = CONTROL/STATUS = DATA 

CS (Chip Select) 

A "low" on this input selects the 8251 A. No reading or 
writing will occur unless the device is selected. When CS is 
high, the Data Bus in the float state and RD and WR will 
have no effect on the chip. 
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Figure 1. 8251 A Block Diagram Showing Data Bus 
Buffer and Read/Write Logic Functions 
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8251 A DATA =» DATA BUS 
DATA BUS =► 8251 A DATA 
STATUS =► DATA BUS 
DATA BUS => CONTROL 
DATA BUS=> 3-STATE 
DATA BUS =► 3-STATE 



WR (Write) 

A "low" on this input informs the 8251 A that the CPU is 
writing data or control words to the 8251 A. 

RD (Read) 

A "low" on this input informs the 8251A that the CPU is 
reading data or status information from the 8251 A. 



Modem Control 

The 8251A has a set of control inputs and outputs that 
can be used to simplify the interface to almost any 
modem. The modem control signals are general purpose 
in nature and can be used for functions other than 
modem control, if necessary. 
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DSR (Data Set Ready) 

The DSR input signal is a general purpose, 1-bit inverting 
input port. Its condition can be tested by the CPU using a 
Status Read operation. The DSR input is normally used to 
test modem conditions such as Data Set Ready. 

DTR (Data Terminal Ready)) 

The DTR output signal is a general purpose, 1-bit inverting 
output port. It can be set "low" by programming th e ap- 
propriate bit in the Command Instruction word. The DTR 
output signal is normally used for modem control such 
as Data Terminal Ready or Rate Select. 

RTS (Request to Send) 

The RTS output signal is a general purpose, 1-bit inverting 
output port. It can be set "low" by programming the ap- 
propriate bit in the Command Instruction word. The RTS 
output signal is normally used for Modem control such as 
Request to Send. 

CTS (Clear to Send) 

A "low" on this input enables the 8251 A to transmit 
serial data if the Tx Enable bit in the Command byte is 
set to a "one." If either a Tx Enable off or CTS off condi- 
tion occurs while the Tx is in operation, the Tx will 
transmit all the data in the USART, written prior to Tx 
Disable command before shutting down. 

Transmitter Buffer 

The Transmitter Buffer accepts parallel data from the Data 
Bus Buffer, converts it to a serial bit stream, inserts the 
appropriate characters or bits (based on the communica- 
tion technique) and outputs a composite serial strea m of 
data on the TxD output pin on the falling edge of TxC. 
Th e tra nsmitter will begin transmission upon being enabled 
if CTS = 0. The TxD line will be held in the marking 
state immediately upon a master Reset or when Tx Enable/ 
CTS off or Tx EMPTY. 

Transmitter Control 

The transmitter Control manages all activities associated 
with the transmission of serial data. It accepts and issues 
signals both externally and internally to accomplish this 
function. 

TxRDY (Transmitter Ready) 

This output signals the CPU that the transmitter is ready to 
accept a data character. The TxRDY output pin can be 
used as an interrupt to the system, since it is masked by 
Tx Disabled, or, for Polled operation, the CPU can check 
TxRDY using a Status Read operation. TxRDY is auto- 
matically reset by the leading edge of WR when a data 
character is loaded from the CPU. 

Note that when using the Polled operation, the TxRDY 
status bit is not masked by Tx Enabled, but will only 
indicate the Empty/Full Status of the Tx Data Input 
Register. 



TxE (Transmitter Empty) 

When the 8251 A has no characters to transmit, the TxEMP- 
TY output will go "high". It resets automatically upon re- 
ceiving a character from the CPU. TxEMPTY can be used to 
indicate the end of a transmission mode, so that the CPU 
"knows" when to "turn the line around" in the half- 
duplexed operational mode. TxEMPTY is independent of 
the Tx Enable bit in the Command instruction. 
In SYNChronous mode, a "high" on this output indicates 
that a character has not been loaded and the SYNC charac- 
ter or characters are about to be or are being transmitted 
automatically as "fillers". TxEMPTY does not go low 
when the SYNC characters are being shifted out. 




.. ► SYNOF.T' 
UFIKDE.T 



Figure 2. 8251A Block Diagram Showing Modem and 
Transmitter Buffer and Control Functions 



TxC (Transmitter Clock) 

The Transmitter Clock controls the rate at which the char- 
acter is to be transmitted. In the Synchron ous tr ansmission 
mode, the Baud Rate (1x) is equal to the TxC frequency. 
In Asynchronous trans missi on mode the baud rate is a 
fraction of the actual TxC frequency. A portion of the 
mode in struct ion selects this factor; it can be 1, 1/16 or 
1/64 the TxC. 

For Example: 

If Ba ud Rate equals 1 10 Baud, 
TxC equals 110 Hz (1x) 
TxC equals 1.76 kHz (16x) 
TxC equals 7.04 kHz (64x). 

The falling edge of TxC shifts the serial data out of the 
8251 A. 
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Receiver Buffer 

The Receiver accepts serial data, converts this serial input 
to parallel format, checks for bits or characters that are 
unique to the communication technique and sends an 
"assembled" character to the CPU. Serial data is inp ut to 
RxD pin, and is clocked in on the rising edge of RxC. 

Receiver Control 

This functional block manages all receiver-related activities 
which consist of the following features: 

The RxD initialization circuit prevents the 8251A from 
mistaking an unused input line for an active low data 
line in the "break condition". Before starting to receive 
serial characters on the RxD line, a valid "1" must first 
be detected after a chip master Reset. Once this has been 
determined, a search for a valid low (Start bit) is en- 
abled. This feature is only active in the asynchronous 
mode, and is only done once for each master Reset. 

The False Start bit detection circuit prevents false starts 
due to a transient noise spike by first detecting the fall- 
ing edge and then strobing the nominal center of the 
Start bit (RxD = low). 

The Parity Toggle F/F and Parity Error F/F circuits are 
used for parity error detection and set the corresponding 
status bit. 

The Framing Error Flag F/F is set if the Stop bit is 
absent at the end of the data byte (asynchronous mode), 
and also sets the corresponding status bit. 

RxRDY (Receiver Ready) 

This output indicates that the 8251A contains a character 
that is ready to be input to the CPU. Rx RDY can be con- 
nected to the interrupt structure of the CPU or, for Polled 
operation, the CPU can check the condition of RxRDY 
using a Status Read operation. 

Rx Enable off both masks and holds RxRDY in the Reset 
Condition. For Asynchronous mode, to set RxRDY, the 
Receiver must be Enabled to sense a Start Bit and a com- 
plete character must be assembled and transferred to the 
Data Output Register. For Synchronous mode, to set 
RxRDY, the Receiver must be enabled and a character 
must finish assembly and be transferred to the Data Output 
Register. 

Failure to read the received character from the Rx Data 
Output Register prior to the assembly of the next Rx Data 
character will set overrun condition error and the previous 
character will be written over and lost. If the Rx Data is 
being read by the CPU when the internal transfer is occur- 
ring, overrun error will be set and the old character will be 
lost. 

RxC (Receiver Clock) 

The Receiver Clock controls the rate at which the character 
is to be received. In Synchronous Mode, the Baud Rate (1x) 
is equal to the actual frequency of RxC. In Asynchronous 
Mode, the Baud Rate is a fraction of the actual RxC fre- 



quency. A portion of the mode instruction selects this 
factor; 1, 1/16 or 1/64 the RxC. 
For Example: 

Baud Rate equals 300 Baud, if 
RxC equals 300 Hz (1x) 
RxC equals 4800 Hz (16x) 
RxC equals 19.2 kHz (64x). 

Baud Rate equals 2400 Baud, if 
RxC equals 2400 Hz (1x) 
RxC equals 38.4 kHz (16x) 
RxC equals 153.6 kHz (64x). 

Data is sampled into the 8251 A on the rising edge of RxC. 

NOTE: In most communications systems, the 8251A will 
be handling both the transmission and reception operations 
of a single link. Consequently, the Rece ive and Transmit 
Baud Rates will be the same. Both TxC and RxC will re- 
quire identical frequencies for this operation and can be 
tied together and connected to a single frequency source 
(Baud Rate Generator) to simplify the interface. 

SYNDET (SYNC Detect)/BRKDET (Break Detect) ) 

This pin is used in SYNChronous Mode for SYNDET and 
may be used as either input or output, programmable 
through the Control Word. It is reset to output mode low 
upon RESET. When used as an output (internal Sync mode), 
the SYNDET pin will go "high" to indicate that the 8251 A 
has located the SYNC character in the Receive mode. If the 
8251 A is programmed to use double Sync characters (bi- 
sync), then SYNDET will go "high" in the middle of the 
last bit of the second Sync character. SYNDET is auto- 
matically reset upon a Status Read operation. 
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Figure 3. 8251A Block Diagram Showing Receiver 
Buffer and Control Functions 
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When used as an input (external SYNC detect mode), a 
positive going signal will cause the 8251 A to start assem- 
bling data characters on the rising edge of the next RxC. 
Once in SYNC , the "high" input signal can be removed, 
the period of RxC. When External SYNC Detect is pro- 
grammed, the Internal SYNC Detect is disabled. 

BREAK DETECT (Async Mode Only) 

This output will go high whenever an all zero word of the 
programmed length (including start bit, data bit, parity bit, 
and one stop bit) is received. Break Detect may also be read 
as a Status bit. It is reset only upon a master chip Reset or 
Rx Data returning to a "one" state. 



ADDRESS BUS 



CONTROL BUS 



I/O R I/O W RESET 



7^ 



\7 



RESET CLK 



Figure 4. 8251 A Interface to 8080 Standard 
System Bus 

DETAILED OPERATION DESCRIPTION 

General 

The complete functional definition of the 8251A is pro- 
grammed by the system's software. A set of control words 
must be sent out by the CPU to initialize the 8251 A to 
support the desired communications format. These control 
words will program the: BAUD RATE, CHARACTER 
LENGTH, NUMBER OF STOP BITS, SYNCHRONOUS or 
ASYNCHRONOUS OPERATION, EVEN/ODD/OFF PAR- 
ITY, etc. In the Synchronous Mode, options are also pro- 
vided to select either internal or external character synchro- 
nization. 

Once programmed, the 8251 A is ready to perform its com- 
munication functions. The TxRDY output is raised "high" 
to signal the CPU that the 8251A is ready to receive a data 
character from the CPU. This output (TxRDY) is reset 
automatically when the CPU writes a character into the 
8251 A. On the other hand, the 8251 A receives serial data 
from the MODEM or I/O device. Upon receiving an entire 
character, the RxRDY output is raised "high" to signal the 
CPU that the 8251 A has a complete character ready for the 
CPU to fetch. RxRDY is reset automatically upon the CPU 
data read operation. 



The 8251 A cannot begin transmission until the Tx Enable 
(Transmitter Enable) bit is set in the Com mand Instruction 
and it has received a Clear To Send (CTS) input. The TxD 
output will be held in the marking state upon Reset. 

Programming the 8251 A 

Prior to starting data transmission or reception, the 8251 A 
must be loaded with a set of control words generated by 
the CPU. These control signals define the complete func- 
tional definition of the 8251A and must immediately fol- 
low a Reset operation (internal or external). 

The control words are split into two formats: 

1. Mode Instruction 

2. Command Instruction 

Mode Instruction 

This format defines the general operational characteristics 
of the 8251 A. It must follow a Reset operation (internal or 
external). Once the Mode Instruction has been written into 
the 8251A by the CPU, SYNC characters or Command In- 
structions may be inserted. 

Command Instruction 

This format defines a status word that is used to control the 
actual operation of the 8251 A. 

Both the Mode and Command Instructions must conform 
to a specified sequence for proper device operation. The 
Mode Instruction must be inserted immediately following a 
Reset operation, prior to using the 8251A for data com- 
munication. 

All control words written into the 8251 A after the Mode In- 
struction will load the Command Instruction. Command 
Instructions can be written into the 8251 A at any time in 
the data block during the operation of the 8251 A. To re- 
turn to the Mode Instruction format, the master Reset bit 
in the Command Instruction word can be set to initiate an 
internal Reset operation which automatically places the 
8251 A back into the Mode Instruction format. Command 
Instructions must follow the Mode Instructions or Sync 
characters. 



C/D = 


1 
1 
1 
1 



1 



1 




MODE INSTRUCTION 




c/6 


SYNC CHARACTER 1 




C/D 


SYNC CHARACTER 2 


C/D = 


COMMAND INSTRUCTION 




C/D • 


; data ; 




C/D 


COMMAND INSTRUCTION 




C/D = 


; DATA : 




C/D 


COMMAND INSTRUCTION 





The second SYNC character is skipped if MODE instruction 
has programmed the 8251A to single character Internal SYNC 
Mode. Both SYNC characters are skipped if MODE instruction 
has programmed the 8251A to ASYNC mode. 



Figure 5. Typical Data Block 
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Mode Instruction Definition 

The 8251A can be used for either Asynchronous or Syn- 
chronous data communication. To understand how the 
Mode Instruction defines the functional operation of the 
8251 A, the designer can best view the device as two sepa- 
rate components sharing the same package, one Asynchro- 
nous the other Synchronous. The format definition can be 
changed only after a master chip Reset. For explanation 
purposes the two formats will be isolated. 

NOTE: When parity is enabled it is not considered as one of 
the data bits for the purpose of programming the word 
length. The actual parity bit received on the Rx Data line 
cannot be read on the Data Bus. In the case of a pro- 
grammed character length of less than 8 bits, the least 
significant Data Bus bits will hold the data; unused bits are 
"don't care" when writing data to the 8251 A, and will be 
"zeros" when reading the data from the 8251 A. 



Asynchronous Mode (Transmission) 

Whenever a data character is sent by the CPU the 8251 A 
automatically adds a Start bit (low level) followed by the 
data bits (least significant bit first), and the programmed 
number of Stop bits to each character. Also, an even or 
odd Parity bit is inserted prior to the Stop bit(s), as de- 
fined by the Mode Instruction. The character is then trans- 
mitted as a serial data stream on the TxD output. The serial 
data is shifted out on the falling edge of TxC at a rate equal 
to 1, 1/16, or 1/64 that of the TxC, as defined by the Mode 
Instruction. BREAK characters can be continuously sent to 
the TxD if commanded to do so. 

When no data characters have been loaded into the 8251 A 
the TxD output remains "high" (marking) unless a Break 
(continuously low) has been programmed. 



Asynchronous Mode (Receive) 

The RxD line is normally high. A falling edge on this line 
triggers the beginning of a START bit. The validity of this 
START bit is checked by again strobing this bit at its nom- 
inal center (16X or 64X mode only). If a low is detected 
again, it is a valid START bit, and the bit counter will 
start counting. The bit counter thus locates the center of 
the data bits, the parity bit (if it exists) and the stop bits. 
If parity error occurs, the parity error flag is set. Data and 
pari ty b its are sampled on the RxD pin with the rising edge 
of RxC. If a low level is detected as the STOP bit, the 
Framing Error flag will be set. The STOP bit signals the end 
of a character. Note that the receiver requires only one stop 
bit, regardless of the number of stop bits programmed. This 
character is then loaded into the parallel I/O buffer of the 
8251 A. The RxRDY pin is raised to signal the CPU that a 
character is ready to be fetched. If a previous character has 
not been fetched by the CPU, the present character replaces 
it in the I/O buffer, and the OVERRUN Error flag is raised 
(thus the previous character is lost). All of the error flags 
can be reset by an Error Reset Instruction. The occurrence 
of any of these errors will not affect the operation of the 
8251 A. 



D, D, D. D„ 



EP PEN L, L 



BAUD RATE FACTOR 






1 





1 








1 


1 


SYNC 
MODE 


(1X1 


(16X) 


(64X) 



CHARACTER LENGTH 






1 





1 








1 


1 


5 
BITS 


6 
BITS 


7 
BITS 


8 
BITS 



NUMBER OF STOP BITS 






1 





1 








1 


1 


INVALID 


1 
BIT 


IVi 
BITS 


2 

BITS 



(ONLY EFFECTS Tx; Rx NEVER 
REQUIRES MORE THAN ONE 
STOP BIT) 



Figure 6. Mode Instruction Format, Asynchronous 
Mode 



TRANSMITTER OUTPUT 



TxD MARKING 



J-M t , I 



DATA BITS 
1 t 



RECEIVER INPUT 



DOES NOT APPEAR 
D0D1 Dx ON THE DATA BUS 

-LL.J. 



DATA BITS 
f I 



L 
L 



TRANSMISSION FORMAT 



PROGRAMMED 

CHARACTER 

LENGTH 



CPU BYTE (5-8 BITS/CHAR) 
(( 



DATA CHARACTER 
i) 



ASSEMBLED SERIAL DATA OUTPUT (TxD) 



DATA CHARACTER 



STOP 

BITS 

if— 



RECEIVE FORMAT 



SERIAL DATA INPUT (RxD) 



START 
BIT 


1 ) 

DATA CHARACTER 
1 t 


PARITY 
BIT 


f )— — 1 

STOP 

BITS 

1 1) ' 



CPU BYTE (58 BITS/CHAR)' 



DATA CHARACTER 
1 ( 



Figure 7. Asynchronous Mode 
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Synchronous Mode (Transmission) 

The TxD output is continuously high until the CPU sends 
its first character to the 8251A which usually is a SYNC 
character. When the CTS line goes low, the first character 
is serially transmitted out. All characters are shifted out on 
the falling edge of TxC. Data is shifted out at the same 
rate as the TxC. 

Once transmission has starte d, the data stream at the TxD 
output must continue at the TxC rate. If the CPU does not 
provide the 8251 A with a data character before the 8251 A 
Transmitter Buffers become empty, the SYNC characters 
(or character if in single SYNC character mode) will be 
automatically inserted in the TxD data stream. In this case, 
the TxEMPTY pin is raised high to signal that the 8251 A is 
empty and SYNC characters are being sent out. TxEMPTY 
does not go low when the SYNC is being shifted out (see 
figure below). The TxEMPTY pin is internally reset by a 
data character being written into the 8251 A. 

AUTOMATICALLY INSERTED BY USART 



/ \\\\\\\v< 



NOMINAL CENTER OF LAST BIT 



Synchronous Mode (Receive) 

In this mode, character synchronization can be internally 
or externally achieved. If the SYNC mode has been pro- 
grammed, ENTER HUNT command should be included in 
the first command instruction word written. Da ta on the 
RxD pin is then sampled in on the rising edge of RxC. The 
content of the Rx buffer is compared at every bit boundary 
with the first SYNC character until a match occurs. If the 
8251 A has been programmed for two SYNC characters, the 
subsequent received character is also compared; when both 
SYNC characters have been detected, the USART ends the 
HUNT mode and is in character synchronization. The 
SYNDET pin is then set high, and is reset automatically by 
a STATUS READ. If parity is programmed, SYNDET 
will not be set until the middle of the parity bit instead of 
the middle of the last data bit. 

In the external SYNC mode, synchronization is achieved by 
applying a high level on the SYNDET pin, thus forcing the 
8251A out of th e HU NT mode. The high level can be 
removed after one RxC cycle. An ENTER HUNT command 
has no effect in the asynchronous mode of operation. 

Parity error and overrun error are both checked in the same 
way as in the Asynchronous Rx mode. Parity is checked 
when not in Hunt, regardless of whether the Receiver is 
enabled or not. 

The CPU can command the receiver to enter the HUNT 
mode if synchronization is lost. This will also set all the 
used character bits in the buffer to a "one", thus prevent- 
ing a possible false SYNDET caused by data that happens 
to be in the Rx Buffer at ENTER HUNT time. Note that 



the SYNDET F/F is reset at each Status Read, regardless of 
whether internal or external SYNC has been programmed. 
This does not cause the 8251 A to return to the HUNT 
mode. When in SYNC mode, but not in HUNT, Sync Detec- 
tion is still functional, but only occurs at the "known" 
word boundaries. Thus, if one Status Read indicates SYN- 
DET and a second Status Read also indicates SYNDET, 
then the programmed SYNDET characters have been re- 
ceived since the previous Status Read. (If double character 
sync has been programmed, then both sync characters have 
been contiguously received to gate a SYNDET indication.) 
When external SYNDET mode is selected, internal Sync 
Detect is disabled, and the SYNDET F/F may be set at 
any bit boundary. 



CHARACTER LENGTH 






1 





1 








1 


1 


5 
BITS 


6 
BITS 


7 
BITS 


8 
BITS 



• PARITY ENABLE 
(1 - ENABLE) 
(0= DISABLE) 



EVEN PARITY GENERATION/CHECK 
1 = EVEN 
= ODD 



EXTERNAL SYNC DETECT 
1 = SYNDET IS AN INPUT 
= SYNDET IS AN OUTPUT 



SINGLE CHARACTER SYNC 
1 = SINGLE SYNC CHARACTER 
= DOUBLE SYNC CHARACTER 



NOTE: IN EXTERNAL SYNC MODE, PROGRAMMING DOUBLE CHARACTER 
SYNC WILL AFFECT ONLY THE Tx. 



Figure 8. Mode Instruction Format 



CPU BYTES (5-8 BITS/CHAR) 



DATA CHARACTERS 



ASSEMBLED SERIAL DATA OUTPUT (TxD) 



SYNC 
CHAR 1 


SYNC 
CHAR 2 


DATA CHARACTERS 



RECEIVE FORMAT 



SERIAL DATA INPUT (RxD) 



SYNC 
CHAR 1 


SYNC 
CHAR 2 


DATA CHARACTERS 



CPU BYTES (5-8 BITS/CHAR) 



DATA CHARACTERS 



Figure 9. Data Format, Synchronous Mode 
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COMMAND INSTRUCTION DEFINITION 

Once the functional definition of the 8251 A has been pro- 
grammed by the Mode Instruction and the Sync Characters 
are loaded (if in Sync Mode) then the device is ready to be 
used for data communication. The Command Instruction 
controls the actual operation of the selected format. Func- 
tions such as: Enable Transmit/Receive, Error Reset and 
Modem Controls are provided by the Command Instruction. 

Once the Mode Instruction has been written into the 8251 A 
and Sync characters inserted, if necessary, then all further 
"control writes" (C/D = 1) will load a Command Instruc- 
tion. A Reset Operation (internal or external) will return 
the 8251 A to the Mode Instruction format 



STATUS READ DEFINITION 

In data communication systems it is often necessary to 
examine the "status" of the active device to ascertain if 
errors have occurred or other conditions that require the 
processor's attention. The 8251A has facilities that allow 
the programmer to "read" the status of the device at any 
time during the functional operation. (The status update is 
inhibited during status read). 

A normal "read" command is issued by the CPU with C/D = 1 
to accomplish this function. 

Some of the bits in the Status Read Format have identical 
meanings to external output pins so that the 8251 A can be 
used in a completely Polled environment or in an interrupt 
driven environment. TxRDY is an exception. 



Note that status update can have a maximum delay of 28 
clock periods from the actual event affecting the status. 



IR RTS ER SBRK RxE DTR TxEN 



TRANSMIT ENABLE 
1 = enable 
= disable 



DATA TERMINAL 

READY 

"high" will force DTR 
output to zero 



RECEIVE ENABLE 
1 =. enable 
= disable 



SEND BREAK 

CHARACTER 

1 = forces TxD "low" 

= normal operation 



ERROR RESET 

1 = reset error flags 

PE, OE, FE 



REQUEST TO SEND 
"high" will force RTS 
output to zero 



INTERNAL RESET 
"high" returns 8251A to 
Mode Instruction Format 



ENTER HUNT MODE' 
1 = enable search for Sync 
Characters 



' (HAS NO EFFECT 
IN ASYNCMODE) 



Note: Error Reset must be performed whenever Rx Enable and 
Enter Hunt are programmed. 

Figure 10. Command Instruction Format 



DSR SYNDET FE 



PE TxEMPTY RxRDY TxRDY 



SAME DEFINITIONS AS I/O PINS 



PARITY ERROR 
The PE flag is set when a parity 
error is detected. It is reset by 
the ER bit of the Command 
Instruction. PE does not inhibit 
operation of the 8251 A. 



OVERRUN ERROR 
The OE flag is set when the CPU 
does not read a character before 
the next one becomes available. 
It is reset by the ER bit of the 
Command Instruction. OE does 
not inhibit operation of the 8251A 
however, the previously c 
character is lost. 



FRAMING ERROR (Async only) 
The FE flag is set when a valid 
Stop bit is not detected at the 
end of every character. It is reset 
by the ER bit of the Command 
Instruction. FE does not inhibit 
the operation of the 8251 A. 



DATA SET READY: Indicates 
that the DSR is at a zero level. 



Note 1: 



TxRDY status bit has different meanings from the 
Tx RDY output pin". The former is not conditioned 
by C TS and TxEN; the latter is conditioned by both 
CTS and TxEN. 
i.e. TxRDY status bit = DB Buffer Empty 

TxRDY pin out = DB Buffer Empty • (CTS=0)- (TxEN = 1 ) 



Figure 11. Status Read Format 
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ADDRESS BUS 




CONTROL BUS 



RxD 
TxD 
DSR 
DTR 



CTS 3- 

RTS >- 



ASYNC 
MODEM 



BAUD 

RATE 

GENERATOR 



PHONE 
LINE 

INTER- 
FACE 



TELEPHONE 
LINE 



Figure 12. Asynchronous Serial Interface to CRT 
Terminal, DC— 9600 Baud 



Figure 14. Asynchronous Interface to Telephone Lines 
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Figure 13. Synchronous Interface to Terminal or 
Peripheral Device 



Figure 15. Synchronous Interface to Telephone Lines 
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ABSOLUTE MAXIMUM RATINGS 1 



Ambient Temperature Under Bias C to 70 C 

Storage Temperatura — 65° C to +150°C 

Voltage On Any Pin 

With Respect to Ground -0.5V to +7V 

Power Dissipation 1 Watt 



*COMMENT: Stresses above those listed under "Absolute 
Maximum Ratings" may cause permanent damage to the 
device. This is a stress rating only and functional opera- 
tion of the device at these or any other conditions above 
those indicated in the operational sections of this specifi- 
cation is not implied. Exposure to absolute maximum 
rating conditions for extended periods may affect device 
reliability. 



D.C. CHARACTERISTICS 

T A = 0°C to 70°C; V C c = 5.0V ±5%; GND = 0V 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


V|L 


Input Low Voltage 


-0.5 


0.8 


V 




V| H 


Input High Voltage 


2.0 


Vcc 


V 




Vol 


Output Low Voltage 




0.45 


V 


Iol = 2.2 mA 


Voh 


Output High Voltage 


2.4 




V 


l OH =-400/iA 


'OFL 


Output Float Leakage 




±10 


juA 


V UT = V CC TO 0.45V 


'iL 


Input Leakage 




±10 


MA 


Vin = V CC TO 0.45V 


'cc 


Power Supply Current 




100 


mA 


All Outputs = High 



CAPACITANCE 

T A = 25°C;Vcc = GND = 0V 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


C|N 


Input Capacitance 




10 


PF 


fc= 1MHz 


Cl/O 


I/O Capacitance 




20 


PF 


Unmeasured pins returned to GND 
























^SPEC. 













-100 -50 +50 +100 

A CAPACITANCE (pF) 



Figure 16. Test Load Circuit 



Figure 17. Typical A Output Delay vs. A 
Capacitance (pF) 
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A.C. CHARACTERISTICS 

T A = 0°C to 70° C; V cc = 5.0V ±5%; GND = 0V 

Bus Parameters (Note 1) 
Read Cycle: 



SYMBOL 


PARAMETER 


MIN. 


MAX. 


UNIT 


TEST CONDITIONS 


tAR 


Address Stable Before READ (CS, C/D) 







ns 


Note 2 


tRA 


Address Hold Time for READ (CS, C/D) 







ns 


Note 2 


*RR 


READ Pulse Width 


250 




ns 




tRD 


Data Delay from READ 




200 


ns 


3, C L =150pF 


tDF 


READ to Data Floating 


10 


100 


ns 





Write Cycle: 



SYMBOL 


PARAMETER 


MIN. 


MAX. 


UNIT 


TEST CONDITIONS 


*AW 


Address Stable Before WRITE 







ns 




tWA 


Address Hold Time for WRITE 







ns 




t WW 


WRITE Pulse Width 


250 




ns 




tow 


Data Set Up Time for WRITE 


150 




ns 




l WD 


Data Hold Time for WRITE 







ns 




tRV 


Recovery Time Between WRITES 


6 




tfJY 


Note 4 



NOTES: 1. AC timings measured VrjH = 2.0, Vol = £.8, and with load circuit of Figure 1. 

2. Chip Select (CS) and Command/Data (C/D) are considered as Addresses. 

3. Assumes that Address is valid before RqI. 

4. This recovery time is for Mode Initialization only. Write Data is allowed only when TxRDY = 1. 
Recovery Time between Writes for Asynchronous Mode is 8 tQy and for Synchronous Mode is 16 tfjY- 



Input Waveforms for AC Tests 



2.4 



0.45 






TEST 
POINTS 



D( 
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Other Timings: 



SYMBOL 


PARAMETER 


MIN. 


MAX. 


UNIT 


TEST CONDITIONS 


*CY 


Clock Period 


320 


1.35 


JUS 


Notes 5, 6 


H 


Clock High Pulse Width 


120 


tCY-90 


ns 




*$ 


Clock Low Pulse Width 


90 




ns 




tR.t F 


Clock Rise and Fall Time 


5 


20 


ns 




tDTx 


TxD Delay from Falling Edge of TxC 




1 


Ms 




tSRx 


Rx Data Set-Up Time to Sampling Pulse 


2 




MS 




tHRx 


Rx Data Hold Time to Sampling Pulse 


2 




Ms 




hx 


Transmitter Input Clock Frequency 












1x Baud Rate 


DC 


64 


kHz 






16x Baud Rate 


DC 


310 


kHz 






64x Baud Rate 


DC 


615 


kHz 




tTPW 


Transmitter Input Clock Pulse Width 












1x Baud Rate 


12 




tCY 






16x and 64x Baud Rate 


1 




tCY 




*TPD 


Transmitter Input Clock Pulse Delay 












1x Baud Rate 


15 




tCY 






16x and 64x Baud Rate 


3 




tCY 




fRx 


Receiver Input Clock Frequency 












1x Baud Rate 


DC 


64 


kHz 






16x Baud Rate 


DC 


310 


kHz 






64x Baud Rate 


DC 


615 


kHz 




tRPW 


Receiver Input Clock Pulse Width 












1x Baud Rate 


12 




tCY 






16x and 64x Baud Rate 


1 




tCY 




tRPD 


Receiver Input Clock Pulse Delay 












1x Baud Rate 


15 




*CY 






16x and 64x Baud Rate 


3 




tCY 




tTxRDY 


TxRDY Pin Delay from Center of last Bit 




8 


tCY 


Note 7 


tTxRDY CLEAR 


TxRDY I from Leading Edge of WR 




150 


ns 


Note 7 


tRxRDY 


RxRDY Pin Delay from Center of last Bit 




24 


tCY 


Note 7 


tRxRDY CLEAR 


RxRDY 1 from Leading Edge of RD 




150 


ns 


Note 7 


tis 


Internal SYNDET Delay from Rising 
Edge of RxC 




24 


tCY 


Note 7 


tES 


External SYNDET Set-Up Time Before 
Falling Edge of RxC 




16 


tCY 


Note 7 


tTxEMPTY 


TxEMPTY Delay from Center of Data Bit 




20 


tCY 


Note 7 


twc 


Control Delay from Rising Edge of 
WRITE (TxEn,DTR, RTS) 




8 


tCY 


Note 7 


*CR 


Control to READ Set-Up Time (DSR, CTS) 




20 


tCY 


Note 7 



5. The TxC and RxC frequencies have the following limitations with respect to CLK. 

For 1x Baud Rate , fj x or fR x < 1/(30 tcy) 

For 16x and 64x Baud Rate, f j x or fR x < 1/(4.5 tcy) 

6. Reset Pulse Width = 6 t^y minimum; System Clock must be running during Reset. 

7. Status update can have a maximum delay of 28 clock periods from the event affecting the status. 
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WAVEFORMS 

System Clock Input 



4t- 






Transmitter Clock & Data 



«««-»«» WtAAAAAAAAAAAAAAA/lAAA/V\AAAAAAAAAAAAA/V 



-I h 
— XT 



J~ 



\ 



X 



tn 



Receiver Clock & Data 



(Rx BAUD COUNTER STARTS HERE) 
RxDATA ^ / START BIT 






/ DATA BIT X DATA BIT 




/ 


. 


, 










RxC (IxMODE) 


f 




1 1 


\ 




8 RxC PERIODS 






RxC (16 MODE) \J\ 
INT SAMPLING 


(16xMODE) 

AAAAAAAAj 

- 


VWWW 


AaAAAAAA)VWWWWVW 




■" «SRX •- 


-« tHRX ► 







Write Data Cycle (CPU - USART) 



DATA IN (D.B.) 



> 



U — ►jtTxRDY CLEAR 
U tww »R 



rT 



£ DATA STABLE ft 



DON'T CARE 



^ 



tWA | 



1L 



Read Data Cycle (CPU - USART) 



DATA OUT (D.B.) 



"N, 



1 



U— »-| tRxRDY CLEAR 



DATA FLOAT 



«-| [-•— «RD ► U-tQF 

-i t DATA OUT A^iS ° A ™ FLOAT 



X 
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Write Control or Output Port Cycle (CPU - USART) 



DTR, RTS 

IN0TE#1| 



:-l 





\ 


tDW - 


-— -«->-|«WD 


■i 




^ 


— * 


tAW 


■> »j tWA 


/ 


f- 


tAW 




■" H tWA 


\ 




/ 



Read Control or Input Port (CPU - USART) 



DSR.CTS 


X 










k— 


tCR "- 






1 


Rd 




\ 


fF 


tRD 


; 


* 


tDF 


DATA OUT 


— r 






{ 






»-| tAR 


Sr 


■j 


h- 










tRA 


C/D 




/ 


tAR 






_ 


tRA 


N 


CS 




A 


* 




V 



NOTE#1: T wc INCLUDES THE RESPONSE TIMING OF A CONTROL BYTE. 
NOTE #2: T CR INCLUDES THE EFFECT OF CTS ON THE TxENBL CIRCUITRY. 



Transmitter Control & Flag Timing (ASYNC Mode) 




DATA CHAR 1 DATA CHAR 2 DATA CHAR 3 



DATA CHAR 4 



EXAMPLE FORMAT = 7 BIT CHARACTER WITH PARITY & 2 STOP BITS. 
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Receiver Control & Flag Timing (ASYNC Mode) 



BREAK DETECT 



4—\- 




DATA CHAR 1 DATA CHAR 2 DATA CHAR 3 



EXAMPLE FORMAT - 7 BIT CHARACTER WITH PARITY & 2 STOP B 



Transmitter Control & Flag Timing (SYNC Mode) 




EXAMPLE FORMAT - 5 BIT CHARACTER WITH PARITY 2 SYNC CHARACTERS. 



Receiver Control & Flag Timing (SYNC Mode) 




SET SYNDET (STATUS BIT)' 
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8205 
HIGH SPEED 1 OUT OF 8 BINARY DECODER 



d I/O Port or Memory Selector 

d Simple Expansion — Enable Inputs 

a High Speed Schottky Bipolar 
Technology — 18 ns Max Delay 

q Directly Compatible with TTL Logic 
Circuits 



□ Low Input Load Current — • 0.25 mA 
Max, 1/6 Standard TTL Input Load 

m Minimum Line Reflection — Low 
Voltage Diode Input Clamp 

□ Outputs Sink 10 mA Min 

□ 16-Pin Dual In-Line Ceramic or Plastic 
Package 



The Intel® 8205 decoder can be used for expansion of systems which utilize input ports, output ports, and memory 
components with active low chip select input. When the 8205 is enabled, one of its 8 outputs goes "low", thus a single 
row of a memory system is selected. The 3-chip enable inputs on the 8205 allow easy system expansion. For very large 
systems, 8205 decoders can be cascaded such that each decoder can drive 8 other decoders for arbitrary memory 
expansions. 

The 8205 is packaged in a standard 16-pin dual in-line package, and its performance is specified over the temperature 
range of 0°C to +75°C, ambient. The use of Schottky barrier diode clamped transistors to obtain fast switching speeds 
results in higher performance than equivalent devices made with a gold diffussion process. 



PIN CONFIGURATION 




LOGIC SYMBOL 




PIN NAMES 



A - A 2 


ADDRESS INPUTS 


E1-E3 


ENABLE INPUTS 


O0-O7 


DECODED OUTPUTS 



ADDRESS 


ENABLE 


OUTPUTS 


A A, 


A 2 


El 


Ej 


E3 
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L 


L 


L 


H 


H 


H 


H 


L 


H 


H 


H 


H 


L L 


H 


L 


L 


H 


H 


H 


H 


H 


L 


H 


H 


H 


H L 


H 


L 


L 


H 


H 


H 


H 


H 


H 


L 


H 


H 


L H 


H 


L 


L 


H 


H 


H 


H 


H 


H 


H 


L 


H 


H H 


H 
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FUNCTIONAL DESCRIPTION 

Decoder 

The 8205 contains a one out of eight binary decoder. It ac- 
cepts a three bit binary code and by gating this input, creates 
an exclusive output that represents the value of the input 
code. 

For example, if a binary code of 101 was present on the A0, 
A1 and A2 address input lines, and the device was enabled, 
an active low signal would appear on the 05 output line. 
Note that all of the other output pins are sitting at a logic 
high, thus the decoded output is said to be exclusive. The 
decoders outputs will follow the truth table shown below in 
the same manner for all other input variations. 

Enable Gate 

When using a decoder it is often necessary to gate the out- 
puts with timing or enabling signals so that the exclusive 
output of the decoded value is synchronous with the overall 
system. 

The 8205 has a built-in function for such gating. The three 
enable inputs (E1, E2, E3) are ANDed together and create 
a single enable signal for the decoder. The combination of 
both active "high" and active "low" device enable inputs 
provides the designer with a powerfully flexible gating func- 
tion to help reduce package count in his system. 



ENABLE GATE 



o 



Figure 1. Enable Gate 
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APPLICATIONS OF THE 8205 

The 8205 can be used in a wide variety of applications in 
microcomputer systems. I/O ports can be decoded from the 
address bus, chip select signals can be generated to select 
memory devices and the type of machine state such as in 
8008 systems can be derived from a simple decoding of the 
state lines (SO, S1, S2) of the 8008 CPU. 

I/O Port Decoder 

Shown in the figure below is a typical application of the 
8205. Address input lines are decoded by a group of 8205s 
(3). Each input has a binary weight. For example, A0 is as- 
signed a value of 1 and is the LSB; A4 is assigned a value of 
16 and is the MSB. By connecting them to the decoders as 
shown, an active low signal that is exclusive in nature and 
represents the value of the input address lines, is available at 
the outputs of the 8205s. 

This circuit can be used to generate enable signals for I/O 
ports or any other decoder related application. 
Note that no external gating is required to decode up to 24 
exclusive devices and that a simple addition of an inverter 
or two will allow expansion to even larger decoder net- 
works. 

Chip Select Decoder 

Using a very similar circuit to the I/O port decoder, an ar- 




ray of 8205s can be used to create a simple interface to a 
24K memory system. 

The memory devices used can be either ROM or RAM and 
are 1K in storage capacity. 8308s and 8102s are the devices 
typically used for this application. This type of memory de- 
vice has ten (10) address inputs and an active "low" chip 
select (CS). The lower order address bits A0-A9 which come 
from the microprocessor are "bussed" to all memory ele- 
ments and the chip select to enable a specific device or group 
of devices comes from the array of 8205s. The output of 
the 8205 is active low so it is directly compatible with the 
memory components. 

Basic operation is that the CPU issues an address to identify 
a specific memory location in which it wishes to "write" or 
"read" data. The most significant address bits A10-A14 are 
decoded by the array of 8205s and an exclusive, active low, 
chip select is generated that enables a specific memory de- 
vice. The least significant address bits A0-A9 identify a 
specific location within the selected device. Thus, all ad 1 
dresses throughout the entire memory array are exclusive 
in nature and are non-redundant. 

This technique can be expanded almost indefinitely to sup- 
port even larger systems with the addition of a few inverters 
and an extra decoder (8205). 



A oM 




Figure 2. I/O Port Decoder 



Figure 3. 32K Memory Interface 
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Logic Element Example 

Probably the most overlooked application of the 8205 is 
that of a general purpose logic element. Using the "on-chip" 
enabling gate, the 8205 can be configured to gate its de- 
coded outputs with system timing signals and generate 
strobes that can be directly connected to latches, flip-flops 
and one-shots that are used throughout the system. 

An excellent example of such an application is the "state 
decoder" in an 8008 CPU based system. The 8008 CPU is- 
sues three bits of information (SO, S1, S2) that indicate the 
nature of the data on the Data Bus during each machine 
state. Decoding of these signals is vital to generate strobes 
that can load the address latches, control bus discipline and 
general machine functions. 

In the figure below a circuit is shown using the 8205 as the 
"state decoder" for an 8008 CPU that not only decodes the 
SO, S1, S2 outputs but gates these signals with the clock 
(phase 2) and the SYNC output of the 8008 CPU. TheTf 



and T2 decoded strobes can connect directly to devices like 
8212s for latching the address information. The other de- 
coded strobes can be used to generate signals to control the 
system data bus, memory timing functions and interrupt 
structure. RESET is connected to the enable gate so that 
strobes are not generated during system reset, eliminating 
accidental loading. 

The power of such a circuit becomes evident when a single 
decoded strobe is logically broken down. Consider T1 out- 
put, the boolean equation for it would be: 



T1 = (S0-S1-S2)-(SYNC-Phase 2-Reset) 

A six input NAND gate plus a few inverters would be need- 
ed to implement this function. The seven remaining outputs 
would need a similar circuit to duplicate their function, 
obviously a substantial savings in components can be 
achieved when using such a technique. 





SYSTEM RESET 



State Control Coding 



So 


s, 


h 


STATE 





1 





T1 





1 


1 


T1I 








1 


T2 











WAIT 


1 








T3 


1 
1 


1 
1 




1 


STOP 
T4 


1 





1 


T5 



Figure 4. 8205 State Decoder Circuit 
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ABSOLUTE MAXIMUM RATINGS' 



Temperature Under Bias: 



Ceramic 
Plastic 



Storage Temperature 
All Output or Supply Voltages 
All Input Voltages 
Output Currents 



-65°C to H25°C 
-65°C to +75°C 

-65°C to+160°C 

-0.5 to +7 Volts 

-1.0 to +5.5 Volts 

125mA 



'COMMENT 

Stresses above those listed under "Absolute Maximum Rat- 
ing" may cause permanent damage to the device. This is a stress 
rating only and functional operation of the device at these or at 
any other condition above those indicated in the operational 
sections of this specification is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 



D.C. CHARACTERISTICS 

T A = 0°C to +75°C, V cc = 5V ±5% 
8205 



SYMBOL 


PARAMETER 


LIMIT 


UNIT 


TEST CONDITIONS 


MIN. 


MAX. 


■f 


INPUT LOAD CURRENT 




-0.25 


mA 


V cc = 5.25V, V p = 0.45V 


'r 


INPUT LEAKAGE CURRENT 




10 


uA 


V cc = 5.25V, V R = 5.25V 


v c 


INPUT FORWARD CLAMP VOLTAGE 




-1.0 


V 


V cc = 4.75V, l c = -5.0 mA 


V 


OUTPUT "LOW" VOLTAGE 




0.45 


V 


V cc = 4.75V, l QL = 10.0 mA 


V OH 


OUTPUT HIGH VOLTAGE 


2.4 




V 


V cc = 4.75V, l QH = -1.5 mA 


V 


INPUT "LOW" VOLTAGE 




0.85 


V 


V CC =5.0V 


V ,H 


INPUT "HIGH" VOLTAGE 


2.0 




V 


V CC =5.0V 


'sc 


OUTPUT HIGH SHORT 
CIRCUIT CURRENT 


-40 


-120 


mA 


V cc = 5.0V, V 0UT = 0V 


v ox 


OUTPUT "LOW" VOLTAGE 
@ HIGH CURRENT 




0.8 


V 


V cc = 5.0V. I 0X = 40 mA 


'cc 


POWER SUPPLY CURRENT 




70 


mA 


V CC = 5 - 25V 



TYPICAL CHARACTERISTICS 



OUTPUT CURRENT VS. 
OUTPUT "LOW" VOLTAGE 











T A • 75°C _ 
















T A = 25"C-~. 








v c 


C = 5 


,0V 












T A = 


OX 


















































































T A 


= 75° 


C— i 
























_T, 


= 


■c 
















-T A = 25'C 









OUTPUT CURRENT VS. 
OUTPUT "HIGH" VOLTAGE 



1 








W\ 


















i/A *i 


A = 2 


5"C 






T 


A = <>°C- 






T A = 75°C 

















































































































































DATA TRANSFER FUNCTION 
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T A = 0°C 
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T A = 75°C- 
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^ 



OUTPUT "LOW" VOLTAGE (V) 



OUTPUT "HIGH" VOLTAGE (VI 



.6 .8 1.0 1.2 1.4 1.6 1.8 2.0 
INPUT VOLTAGE (V) 
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SWITCHING CHARACTERISTICS 



Conditions of Test: 

Input pulse amplitudes: 2.5V 

Input rise and fall times: 5 nsec 
between 1V and 2V 

Measurements are made at 1.5V 



Test Load 






Sm^x^jH 



All Transistors 2N2369 or Equivalent. C L = 30 pF 



Test Waveforms 



ADDRESS OR ENABLE 
INPUT PULSE 



/ 



X 



X 



A.C. CHARACTRISTICS 

T A = 0°C to +75°C, V C c = 5V ±5% unless otherwise specified. 



SYMBOL 


PARAMETER 


MAX. LIMIT 


UNIT 


TEST CONDITIONS 


t + + 


ADDRESS OR ENABLE TO 
OUTPUT DELAY 


18 


ns 




t_ + 


18 


ns 




t + _ 


18 


ns 




t 


18 


ns 




C di 

HN 


INPUT CAPACITANCE P8205 


4(typ.) 


pF 


f = 1 MHz, Vcc = 0V 




C8205 


5(typ.) 


pF 


V b , AS = 2.0V.Ta = 25°C 



1. This parameter is periodically sampled and is not 100% tested. 



TYPICAL CHARACTERISTICS 



ADDRESS OR ENABLE TO OUTPUT 
DELAY VS. LOAD CAPACITANCE 







v CC = 5 ° V 








15 


T A=2 


5"C 




Y'**' 


uj g 
2 < 


\,* 




< 


10 
5 














l ri— - — -— ~ 













50 100 150 

LOAD CAPACITANCE (pF) 



ADDRESS OR ENABLE TO OUTPUT 
DELAY VS. AMBIENT TEMPERATURE 





v cc = 


5.0V 
30 pF 




'._.'-_ 






t_. 








'». 

















AMBIENT TEMPERATURE (°C) 
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8214 
PRIORITY INTERRUPT CONTROL UNIT 



Q Eight Priority Levels 

□ Current Status Register 

□ Priority Comparator 



□ Fully Expandable 

□ High Performance (50ns) 

□ 24-Pin Dual In-Line Package 



The 821 4 is an eight level priority interrupt control unit designed to simplify interrupt driven microcomputer 
systems. 

The PICU can accept eight requesting levels; determine the highest priority, compare this priority to a soft- 
ware controlled current status register and issue an interrupt to the system along with vector information to 
identify the service routine. 

The 8214 is fully expandable by the use of open collector interrupt output and vector information. Control 
signals are also provided to simplify this function. 

The PICU is designed to support a wide variety of vectored interrupt structures and reduce package count 
in interrupt driven microcomputer systems. 



PIN CONFIGURATION 



LOGIC DIAGRAM 



%c 




- \S— 


24 


3 v cc 


»,c 


2 




23 


^J ECS 


^c 


3 




22 


3^ 


SGS Q 


4 




21 


IK 


INT Q 


5 




20 


3*> 


clkQ 

INTE fjj 


6 


8214 


19 
18 


3«* 

3», 


^C 


8 






3 ^ 


^c 


9 




16 


3«> 


^c 


10 




15 


3"~o 


ELR [^ 


11 




14 


^ ENLG 


GND Q 


12 




13 


ZJ ETLG 



PIN NAMES 



INPUTS 




B "7 


REQUEST LEVELS (R 7 HIGHEST PRIORITY) 


B -B 2 


CURRENT STATUS 


SGS 


STATUS GROUP SELECT 


ECS 


ENABLE CURRENT STATUS 


INTE 


INTERRUPT ENABLE 


CLK 


CLOCK (INT F-F) 


ELR 


ENABLE LEVEL READ 


ETLG 


ENABLE THIS LEVEL GROUP 


OUTPUTS 




A^X, 


REQUEST LEVELS 1 OPEN 


INT 


INTERRUPT (ACT. LOW) J COLLECTOR 


ENLG 


ENABLE NEXT LEVEL GROUP 



|rr> elr 

[13>ETLC 




D> b - 
[E> b,- 
H> Jh- 

QT> sgs — 

[23> ECS-o 



CURRENT 
STATUS 
REGISTER 



_c°. 



tc 



(T> INTE- 

(T> clk- 



I ■ INT 



PRIORITY 
COMPARATOR 



tc 



-int nr> 
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D.C. AND OPERATING CHARACTERISTICS 

ABSOLUTE MAXIMUM RATINGS* 

Temperature Under Bias 0°C to 70°C 

Storage Temperature -65°C to +150°C 

All Output and Supply Voltages -0.5V to +7V 

All Input Voltages -1.0V to +5.5V 

Output Currents 100 mA 

"COMMENT: Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating 
only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specifi- 
cations is not implied. Exposure to absolute maximum ratings for extended periods may affect device reliability. 



T A = 0°C to +70°C, V cc = 5V ±5%. 



Symbol 


Parameter 


Limits 


Unit 


Conditions 


Min. 


TypJU 


Max. 


V C 


Input Clamp Voltage (all inputs) 






-1.0 


V 


lc=-5mA 


"f 


Input Forward Current: ETLG input 

all other inputs 




-.15 
-.08 


-0.5 
-0.25 


mA 
mA 


V F =0.45V 


Ir 


Input Reverse Current: ETLG input 

all other inputs 






80 
40 


HA 
liA 


V R =5.25V 


Vil 


Input LOW Voltage: all inputs 






0.8 


V 


V CC =5.0V 


V|H 


Input HIGH Voltage: all inputs 


2.0 






V 


V CC =5.0V 


■cc 


Power Supply Current 




90 


130 


mA 


See Note 2. 


Vol 


Output LOW Voltage: all outputs 




.3 


.45 


V 


IOL = 1 5mA 


Voh 


Output HIGH Voltage: ENLG output 


2.4 


3.0 




V 


l H=-1rnA 


•os 


Short Circuit Output Current: ENLG output 


-20 


-35 


-55 


mA 


V O s=0V,V C c=5.0V 


'CEX 


Output Leakage Current: INT and Aq-A2 






100 


juA 


V C ex=5.25V 



NOTES: 

1. Typica 

2. B -B 2 , 



I values are for T A = 25° C, V<x = 5 - 0V - 

SGS, CLK, R0-R4 grounded, all other inputs and all outputs open. 
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A.C. CHARACTERISTICS AND WAVEFORMS T A = 0°C to +70°C, V cc = 


+5V ±5% 










Parameter 


Limits 




Symbol 


Min. 


Typ.Ml 


Max. 


Unit 


tCY 


CLK Cycle Time 


80 


50 




ns 


tp w 


CLK, ECS, INT Pulse Width 


25 


15 




ns 


tiss 


INTE Setup Time to CLK 


16 


12 




ns 


tlSH 


INTE Hold Time after CLK 


20 


10 




ns 


tETCS 121 


ETLG Setup Time to CLK 


25 


12 




ns 


tETCH 121 


ETLG Hold Time After CLK 


20 


10 




ns 


tECCS [21 


ECS Setup Time to CLK 


80 


50 




ns 


tECCH 13 ' 


ECS Hold Time After CLK 









ns 


tECRS [31 


ECS Setup Time to CLK 


110 


70 




ns 


t ECRH (3] 


ECS Hold Time After CLK 











tEcss t2] 


ECS Setup Time to CLK 


75 


70 




ns 


tECSH [2] 


ECS Hold Time After CLK 









ns 


t D cs [2] 


SGS and B^-B^ Setup Time to CLK 


70 


50 




ns 


t DCH t2] 


SGS and B^-B^ Hold Time After CLK 









ns 


tRCS l3] 


R0-R7 Setup Time to CLK 


90 


55 




ns 


tRCH [3] 


Ro-R~7 Hold Time After CLK 









ns 


^cs 


INT Setup Time to CLK 


55 


35 




ns 


tci 


CLK to INT Propagation Delay 




15 


25 


ns 


tRIS l4) 


R^-R7 Setup Time to [NT 


10 







ns 


tR|H [4] 


Ru"-R^ Hold Time After INT 


35 


20 




ns 


*RA 


R0-R7 to A0-A2 Propagation Delay 




80 


100 


ns 


tELA 


ELR to A -A2 Propagation Delay 




40 


55 


ns 


tECA 


ECS to A -A2 Propagation Delay 




100 


120 


ns 


*ETA 


ETLG to A0-A2 Propagation Delay 




35 


70 


ns 


tDECS [4] 


SGS and B0-B2 Setup Time to ECS 


15 


10 




ns 


tDECH 141 


SGS and B^-B^ Hold Time After ECS 


15 


10 




ns 


tREN 


R0-R7 to ENLG Propagation Delay 




45 


70 


ns 


*ETEN 


ETLG to ENLG Propagation Delay 




20 


25 


ns 


tECRN 


ECS to ENLG Propagation Delay 




85 


90 


ns 


tECSN 


ECS to ENLG Propagation Delay 




35 


55 


ns 



CAPACITANCE [5] 





Parameter 


Limits 




Symbol 


Min. 


Typ.m 


Max 


Unit 


C IN 


Input Capacitance 




5 


10 


pF 


C OUT 


Output Capacitance 




7 


12 


pF 



TEST CONDITIONS: V B)AS = 2.5V, V cc = 5V, T A = 25°C, f = 1 MHz 
NOTE 5. This parameter is periodically sampled and not 100% tested. 
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WAVEFORMS 



8214 



B B 2 )l( 



XZZX. 



X 



^y 



XIX 



j£££S_ 



X 



XIXZX 



/ 



-4- <i 



'ECRH 
ECCH 



\-J 



X! 



'PW "CI 



\ 



\_/ 



X 



xnzr. 



x 



NOTES: 

' 1 ' Typical values are for T A = 25° C ,Vcc = 5.0V. 

' Required for proper operation if ISE is enabled during next clock pulse. 



(3) 



These times are not required for proper operation but for desired change in interrupt flip-flop. 



' ' Required for new request or status to be properly loaded. 



TEST CONDITIONS: 

Input pulse amplitude: 2.5 volts. 

Input rise and fall times: 5 ns between 1 and 2 volts. 

Output loading of 15 mA and 30 pf. 

Speed measurements taken at the 1.5V levels. 



TEST LOAD CIRCUIT 



OUT O » 
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4 BIT PARALLEL BIDIRECTIONAL BUS DRIVER 



a Data Bus Buffer Driver for 8080 CPU 

o Low Input Load Current — .25 mA 
Maximum 

b High Output Drive Capability for 
Driving System Data Bus 



a 3.65V Output High Voltage for Direct 
Interface to 8080 CPU 

° Three State Outputs 

a Reduces System Package Count 



The 8216/8226 is a 4-bit bi-directional bus driver/receiver. 

All inputs are low power TTL compatible. For driving MOS, the DO outputs provide a high 3.65V V h- and for high capaci- 
tance terminated bus structures, the DB outputs provide a high 50mA Iql capability. 

A non-inverting (8216) and an inverting (8226) are available to meet a wide variety of applications for buffering in micro- 
computer systems. 



PIN CONFIGURATION 



LOGIC DIAGRAM 
8216 



LOGIC DIAGRAM 
8226 
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Dl od 



4 8216/ 13 

5 8226 12 



|V CC 

1 dien di o o- 



Z] DB 3 
Zl Dl 3 
Zl D0 2 
Zl DB 2 
Zl Dl 2 



PIN NAMES 



DB -DB 3 


DATA BUS 
BI-DIRECTIONAL 


DI0-DI3 


DATA INPUT 


DO„-D0 3 


DATA OUTPUT 


DIEN 


DATA IN ENABLE 
DIRECTION CONTROL 


CS 


CHIP SELECT 



DO, o- 



D0 2 O- 



Dl 3 O- 



DO3O- 



£ 



£ 



tf= 



it y 



-O DB„ 



-O DB, 



-O DB 3 



DI O- 



DO, O- 



DOjO- 



DO3O- 



^ 



& 



^ 



-t^ 



^ 



^ 



^ 



ri_Q 



-O DB 



-O DB1 



-O DB 2 



-O DB 3 
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FUNCTIONAL DESCRIPTION 

Microprocessors like the 8080 are MOS devices and are 
generally capable of driving a single TTL load. The same is 
true for MOS memory devices. While this type of drive is 
sufficient in small systems with few components, quite often 
it is necessary to buffer the microprocessor and memories 
when adding components or expanding to a multi-board 
system. 

The 8216/8226 is a four bit bi-directional bus driver specif- 
ically designed to buffer microcomputer system components. 

Bi-Directional Driver 

Each buffered line of the four bit driver consists of two 
separate buffers that are tri-state in nature to achieve direct 
bus interface and bi-directional capability. On one side of 
the driver the output of one buffer and the input of another 
are tied together (DB), this side is used to interface to the 
system side components such as memories, I/O, etc., be- 
cause its interface is direct TTL compatible and it has high 
drive (50mA). On the other side of the driver the inputs 
and outputs are separated to provide maximum flexibility. 
Of course, they can be tied together so that the driver can 
be used to buffer a true bi-directional bus such as the 8080 
Data Bus. The DO outputs on this side of the driver have a 
special high voltage output drive capability (3.65V) so that 
direct interface to the 8080 and 8008 CPUs is achieved with 
an adequate amount of noise immunity (350m V worst case) . 



Control Gating DIEN, CS 

The CS input is actually a device select. When it is "high" 
the output drivers are all forced to their high-impedance 
state. When it is at "zero" the device is selected (enabled) 
and the direction of the data flow is determined by the 
DIEN input. 

The DIEN input controls the direction of data flow (see 
Figure 1) for complete truth table. This direction control 
is accomplished by forcing one of the pair of buffers into its 
high impedance state and allowing the other to transmit its 
data. A simple two gate circuit is used for this function. 

The 8216/8226 isadevicethat will reduce component count 
in microcomputer systems and at the same time enhance 
noise immunity to assure reliable, high performance op- 
eration. 



(a) 8216 



Dl O- 



Dl 2 o- 



D0 2 O- 



D0 3 o- 



(b) 8226 
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Figure 1. 8216/8226 Logic Diagrams 
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APPLICATIONS OF 8216/8226 



8080 Data Bus Buffer 

The 8080 CPU Data Bus is capable of driving a single TTL 
load and is more than adequate for small, single board sys- 
tems. When expanding such a system to more than one board 
to increase I/O or Memory size, it is necessary to provide a 
buffer. The 8216/8226 is a device that is exactly fitted to 
this application. 

Shown in Figure 2 are a pair of 8216/8226 connected di- 
rectly to the 8080 Data Bus and associated control signals. 
The buffer is bi-directional in nature and serves to isolate the 
CPU data bus. 

On the system side, the DB lines interface with standard 
semiconductor I/O and Memory components and are com- 
pletely TTL compatible. The DB lines also provide a high 
drive capability (50mA) so that an extremely large system 
can be dirven along with possible bus termination networks. 

On the 8080 side the Dl and DO lines are tied together and 
are directly connected to the 8080 Data Bus for bi-directional 
operation. The DO outputs of the 8216/8226 have a high 
voltage output capability of 3.65 volts which allows direct 
connection to the 8080 whose minimum input voltage is 
3.3 volts. It also gives a very adequate noise margin of 
350mV (worst case). 

The DIEN inputs to 821 6/8226 is connected directly to the 
8080. DIEN is tied to DBIN so that proper bus flow is 
maintained, and CS is tied to BUSEN so that the system 
side Data Bus will be 3-stated when a Hold request has been 
acknowledged during a DMA activity. 

Memory and I/O Interface to a Bi-directional Bus 

In large microcomputer systems it is often necessary to pro- 
vide Memory and I/O with their own buffers and at the same 
time maintain a direct, common interface to a bi-directional 
Data Bus. The 8216/8226 has separated data in and data 
out lines on one side and a common bi-directional set on the 
other to accomodate such a function. 

Shown in Figure 3 is an example of how the 8216/8226 is 
used in this type of application. 

The interface to Memory is simple and direct. The memories 
used are typically Intel® 8102, 81 02A, 8101 or 8107B-4 and 
have separate data inputs and outputs. The Dl and DO lines 
of the 8216/8226 tie to them directly and und er con trol of 
the MEMR signal, which is connected to the DIEN input, 
an interface to the bi-directional Data Bus is maintained. 

The interface to I/O is similar to Memory. The I/O devices 
used are typically Intel® 825 5s, an d can be used for both 
input and output ports. The I/O R signal is connected di- 
rectly to the DIEN input so that proper data flow from the 
I/O device to the Data Bus is maintained. 



The 8216/8226 can be used in a wide variety of other buf- 
fering functions in microcomputer systems such as Address 
Bus Drivers, Drivers to peripheral devices such as printers, 
and as Drivers for long length cables to other peripherals or 
systems. 




SYSTEM 
-DATA 
BUS 



Figure 2. 8080 Data Bus Buffer. 
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Figure 3. Memory and I/O Interface to a Bi-Directional Bus. 
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D.C. AND OPERATING CHARACTERISTICS 

ABSOLUTE MAXIMUM RATINGS* 

Temperature Under Bias 0°C to 70°C 

Storage Temperature -65°C to +150°C 

All Output and Supply Voltages -0.5V to +7V 

All Input Voltages -1 .0V to +5.5V 

Output Currents 125 mA 

'COMMENT: Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating 
only and functional operation of the device at these or at any other condition above those indicated in the operational sections of this specifi- 
cation is not implied. 



T A = 0°C to +70°C,V CC =+5V±5% 





Parameter 


Limits 


Unit 




Symbol 


Min. 


Typ. 


Max. 


Conditions 


"F1 


Input Load Current DIEN, CS 




-0.15 


-.5 


mA 


V F = 0.45 


lF2 


Input Load Current All Other Inputs 




-0.08 


-.25 


mA 


V F = 0.45 


"ri 


Input Leakage Current DIEN, CS 






20 


MA 


V R = 5.25V 


■r2 


Input Leakage Current Dl Inputs 






10 


jiA 


V R = 5.25V 


v c 


Input Forward Voltage Clamp 






-1 


V 


l c = -5mA 


V| L 


Input "Low" Voltage 






.95 


V 




V| H 


Input "High" Voltage 


2.0 






V 




Hol 


Output Leakage Current DO 
(3-State) DB 






20 
100 


AtA 


V = 0.45V/5.25V 




8216 




95 


130 


mA 




•cc 


Power Supply Current 

8226 




85 


120 


mA 




V L1 


Output "Low" Voltage 




0.3 


.45 


V 


DO Outputs l 0L =15mA 
DB Outputs l L=25mA 


V OL2 


8216 




0.5 


.6 


V 


DB Outputs l L = 55mA 


8226 




0.5 


.6 


V 


DB Outputs l OL =50mA 


V OH1 


Output "High" Voltage 


3.65 


4.0 




V 


DO Outputs l 0H = -1mA 


V OH2 


Output "High" Voltage 


2.4 


3.0 




V 


DB Outputs Iqh = -10mA 


'os 


Output Short Circuit Current 


-15 
-30 


-35 
-75 


-65 
-120 


mA 
mA 


DO Outputs V = 0V, 
DB Outputs V CC =5.0V 



NOTE: Typical values are for T/\ = 25° C, Vcc = 50V - 
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WAVEFORMS 



X 



X 



X 



X 




A.C. CHARACTERISTICS 

T A = 0°C to +70°C, V cc = +5V ±5% 





Parameter 


Limits 


Unit 




Symbol 


Min. 


Typ.fi] 


Max. 


Conditions 


TpD1 


Input to Output Delay DO Outputs 




15 


25 


ns 


C^SOpF.R^OOn 
R 2 =600J2 


T PD2 


Input to Output Delay DB Outputs 
8216 




20 


30 


ns 


C L =300pF, R!=90n 




8226 




16 


25 


ns 


R 2 = 18012 


T E 


Output Enable Time 

8216 




45 


65 


ns 


(Note 2) 




8226 




35 


54 


ns 


(Note 3) 


Td 


Output Disable Time 




20 


35 


ns 


(Note 4) 



TEST CONDITIONS: 

Input pulse amplitude of 2.5V. 

Input rise and fall times of 5 ns between 1 and 2 volts. 

Output loading is 5 mA and 10 pF. 

Speed measurements are made at 1.5 volt levels. 



TEST LOAD CIRCUIT 



Capacitance 



15] 






Parameter 


Limits 




Symbol 


Min. 


Typ.m 


Max. 


Unit 


C IN 


Input Capacitance 




4 


8 


pF 


C OUT1 


Output Capacitance 




6 


10 


pF 


C OUT2 


Output Capacitance 




13 


18 


pF 



TEST CONDITIONS: V B | AS = 2.5V, V cc = 5.0V, T A = 25°C, f = 1 MHz. 

NOTES: 1. Typical values are for T A = 25°C, Vqc = 5.0V. 

2. DO Outputs, C[_ = 30pF, H-[ = 300/10 Kn, R 2 = 180/1 Kn; DB Outputs, C|_ = 300pF, F^ = 90/10 Kn, R 2 = 180/1 Kn. 

3. DO Outputs, C|_ = 30pF, Ri = 300/10 Kfi, R 2 = 600/1 K; DB Outputs, C L = 300pF, Ri = 90/10 Kn, R 2 = 180/1 Kn. 

4. DO Outputs, C L = 5pF, Rt = 300/10 Kn, R 2 = 600/1 Kn; DB Outputs, C L = 5pF, R, = 90/10 Kn, R 2 = 180/1 Kn. 

5. This parameter is periodically sampled and not 100% tested. 
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8253/8253-5 
PROGRAMMABLE INTERVAL TIMER 



d MCS— 85™ Compatible 8253-5 

□ 3 Independent 16-Bit Counters 
a DC to 2 MHz 

□ Programmable Counter Modes 



d Count Binary or BCD 

□ Single +5V Supply 

□ 24-Pin Dual In-Line Package 



The Intel® 8253 is a programmable counter/timer chip designed for use as an Intel microcomputer peripheral. It uses 
nMOS technology with a single +5V supply and is packaged in a 24-pin plastic DIP. 

It is organized as 3 independent 16-bit counters, each with a count rate of up to 2 MHz. All modes of operation are soft- 
ware programmable. 



PIN CONFIGURATION 



BLOCK DIAGRAM 



° 5 c 

D 3 C 
D 2 C 
D,C 

CLKOC 

OUTOC 

GATEOC 

gndC 



6 8253 19 



3v cc 

UWR 

Urd 
DCs 
Da, 
Ha 

DCLK2 
I] OUT 2 
U GATE 2 
DCLK 1 

Ugate 1 

DOUT 1 



PIN NAMES 



D,D 


DATA BUS (8 BIT) 


CLK N 


COUNTER CLOCK INPUTS 


GATEN 


COUNTER GATE INPUTS 


OUT N 


COUNTER OUTPUTS 


RD 


READ COUNTER 


WR 


WRITE COMMAND OR DATA 


cs 


CHIP SELECT 


A Q -A, 


COUNTER SELECT 


Vcc 


+5 VOLTS 


GND 


GROUND 



READ/ 
WRITE 
LOGIC 



CONTROL 

WORD 
REGISTER 



o 



INTERNAL BUS 



CLKO 
GATEO 



GATE 1 
■ OUT 1 



CLK 2 
- GATE 2 
-OUT 2 



Co Intel Corporation, 1978 



February, 1978 
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FUNCTIONAL DESCRIPTION 

General 

The 8253 is a programmable interval timer/counter 
specifically designed for use with the Intel 1 " Micro- 
computer systems. Its function is that of a general 
purpose, multi-timing element that can be treated as an 
array of I/O ports in the system software. 

The 8253 solves one of the most common problems in any 
microcomputer system, the generation of accurate time 
delays under software control. Instead of setting up timing 
loops in systems software, the programmer configures the 
8253 to match his requirements, initializes one of the 
counters of the 8253 with the desired quantity, then upon 
command the 8253 will count out the delay and interrupt 
the CPU when it has completed its tasks. It is easy to see 
that the software overhead is minimal and that multiple 
delays can easily be maintained by assignment of priority 
levels. 

Other counter/timer functions that are non-delay in 
nature but also common to most microcomputers can be 
implemented with the 8253. 

• Programmable Rate Generator 

• Event Counter 

• Binary Rate Multiplier 

• Real Time Clock 

• Digital One-Shot 

• Complex Motor Controller 

Data Bus Buffer 

This 3-state, bi-directional, 8-bit buffer is used to interface 
the 8253 to the system data bus. Data is transmitted or 
received by the buffer upon execution of INput or OUTput 
CPU instructions. The Data Bus Buffer has three basic 
functions. 

1. Programming the MODES of the 8253. 

2. Loading the count registers. 

3. Reading the count values. 

Read/Write Logic 

The Read/Write Logic accepts inputs from the system bus 
and in turn generates control signals for overall device 
operation. It is enabled or disabled by CS so that no 
operation can occur to change the function unless the 
device has been selected by the system logic. 

RD (Read) 

A "low" on this input informs the 8253 that the CPU is 
inputting data in the form of a counters value. 

WR (Write) 

A "low" on this input informs the 8253 that the CPU is 
outputting data in the form of mode information or loading 
counters. 



AO, A1 

These inputs are normally connected to the address bus. 
Their function is to select one of the three counters to be 
operated on and to address the control word register for 
mode selection. 

CS (Chip Select) 

A "low" on this input enables the 8253. No reading or 
writing will occur unless the device is selected. The CS 
input has no effect upon the actual operation of the 
counters. 



u, A- 



V 



DATA 

BUS 

BUFFER 



CO 



READ/ 
WRITE 
LOGIC 









INTERNAL BUS 



COUNTER 

*0 



-CLKO 

GAIL" 
-OUT0 



- CLK 1 

- GATE 1 
-OUT1 



-CLK2 
-GATE 2 
- OUT 2 



Figure 1. Block Diagram Showing Data Bus Buffer and 
Read/Write Logic Functions 
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1 
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Read Counter No. 








1 
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Read Counter No. 1 
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Read Counter No. 2 
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No-Operation 3-State 
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X 


X 


Disable 3-State 
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1 


X 


X 


No-Operation 3-State 
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Control Word Register 

The Control Word Register is selected when A0,A1 are 11. 
It then accepts information from the data bus buffer and 
stores it in a register. The information stored in this 
register controls the operational MODE of each counter, 
selection of binary or BCD counting and the loading of 
each count register. 

The Control Word Register can only be written into; no 
read operation of its contents is available. 

Counter #0, Counter #1, Counter #2 

These three functional blocks are identical in operation so 
only a single Counter will be described. Each Counter 
consists of a single, 16-bit, pre-settable, DOWN counter. 
The counter can operate in either binary or BCD and its 
input, gate and output are configured by the selection of 
MODES stored in the Control Word Register. 

The counters are fully independent and each can have 
separate Mode configuration and counting operation, 
binary or BCD. Also, there are special features in the 
control word that handle the loading of the count value so 
that software overhead can be minimized for these 
functions. 

The reading of the contents of each counter is available to 
the programmer with simple READ operations for event 
counting applications and special commands and logic 
are included in the 8253 so that the contents of each 
counter can be read "on the fly" without having to inhibit 
the clock input. 

8253 SYSTEM INTERFACE 

The 8253 is a component of the Intel™ Microcomputer 
Systems and interfaces in the same manner as all other 
peripherals of the family. It is treated by the systems 
software as an array of peripheral I/O ports; three are 
counters and the fourth is a control register for MODE 
programming. 

Basically, the select inputs A0, A1 connect to the A0, A1 
address bus signals of the CPU. The CS can be derived 
directly from the address bus using a linear select method. 
Or it can be connected to the output of a decoder, such as 
an Intel® 8205 for larger systems. 




INfrRUAI. uus. 



Figure 2. Block Diagram Showing Control Word 
Register and Counter Functions 
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Figure 3. 8253 System Interface 



8253/8253-5 



M — MODE: 



OPERATIONAL DESCRIPTION 

General 

The complete functional definition of the 8253 is 
programmed by the systems software. A set of control 
words must be sent out by the CPU to initialize each 
counter of the 8253 with the desired MODE and quantity 
information. These control words program the MODE, 
Loading sequence and selection of binary or BCD 
counting. 

Once programmed, the 8253 is ready to perform whatever 
timing tasks it is assigned to accomplish. 

The actual counting operation of each counter is 
completely independent and additional logic is provided 
on-chip so that the usual problems associated with 
efficient monitoring and management of external, 
asynchronous events or rates to the microcomputer 
system have been eliminated. 

Programming the 8253 

All of the MODES for each counter are programmed by the 
systems software by simple I/O operations. 

Each counter of the 8253 is individually programmed by 
writing a control word into the Control Word Register. 
(AO, A1 = 11) 

Control Word Format 



D 7 


D 6 


D 5 


D 4 


D 3 


D 2 


Di 


Do 


SC1 


SCO 


RL1 


RLO 


M2 


M1 


MO 


BCD 



Definition of Control 
SC — Select Counter: 
SCI SCO 









Select Counter 





1 


Select Counter 1 


1 





Select Counter 2 


1 


1 


Illegal 



RL — Read/Load: 
RL1 RLO 









Counter Latching operation (see 
READ/WRITE Procedure Section) 


1 





Read/Load most significant byte only. 





1 


Read/Load least significant byte only. 


1 


1 


Read/Load least significant byte first, 
then most significant byte. 



M2 


M1 


MO 













ModeO 








1 


Mode 1 


X 


1 





Mode 2 


X 


1 


1 


Mode 3 


1 








Mode 4 


1 





1 


Mode 5 



BCD: 






Binary Counter 16-bits 


1 


Binary Coded Decimal (BCD) Counter 
(4 Decades) 



MODE Definition 

MODE: Interrupt on Terminal Count. The output will be 
initially low after the mode set operation. After the 
count is loaded into the selected count register, the out- 
put will remain low and the counter will count. When ter- 
minal count is reached the output will go high and re- 
main high until the selected count register is reloaded 
with the mode or a new count is loaded. 

Reloading a counter register during counting results in 
the following: 

(1) Load 1st byte stops the current counting. 

(2) Load 2nd byte starts the new count. 

MODE 1: Programmable One-Shot. The output will go 
low on the count following the rising edge of the gate in- 
put. 

The output will go high on the terminal count. If a new 
count value is loaded while the output is low it will not 
affect the duration of the one-shot pulse until the suc- 
ceeding trigger. The current count can be read at any 
time without affecting the one-shot pulse. 

The one-shot is retriggerable, hence the output will re- 
main low for the full count after any rising edge of the 
gate input. 
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MODE 2: Rate Generator. Divide by N counter. The out- 
put will be low for one period of the input clock. The 
period from one output pulse to the next equals the 
number of input counts in the count register. If the 
count register is reloaded between output pulses the 
present period will not be affected, but the subsequent 
period will reflect the new value. 

The gate input, when low, will force the output high. 
When the gate input goes high, the counter will start 
from the initial count. Thus, the gate input can be used 
to synchronize the counter. 

When this mode is set, the output will remain high until 
after the count register is loaded. The output then can 
also be synchronized by software. 

MODE 3: Square Wave Rate Generator. Similar to MODE 
2 except that the output will remain high until one half 
the count has been completed (for even numbers) and 
go low for the other half of the count. If the count is odd, 
the output will be high for (N + 1)/2 counts and low for 
(N-1)/2 counts. 

If the counter register is reloaded with a new value dur- 
ing counting, this new value will be reflected immedi- 
ately after after the output transition of the current 
count. 

MODE 4: Software Triggered Strobe. After the mode is 
set, the output will be high. When the count is loaded, 
the counter will begin counting. On terminal count, the 
output will go low for one input clock period, then will 
go high again. 

If the count register is reloaded between output pulses 
the present period will not be affected, but the subse- 
quent period will reflect the new value. The count will be 
inhibited while the gate input is low. Reloading the 
counter register will restart counting beginning with the 
new number. 



MODE 5: Hardware Triggered Strobe. The counter will 
start counting after the rising edge of the trigger input 
and will go low for one clock period when the terminal 
count is reached. The counter is retriggerable. The out- 
put will not go low until the full count after the rising 
edge of any trigger. 







Signal 


Low 










^Status 


Or Going 






Modes 






Low 


Rising 


High 









Disables 
counting 





Enables 
counting 




1 






1) Initiates 
counting 

2) Resets output 
after next clock 






2 




1) Disables 












counting 


Initiates 


Enables 








2) Sets output 


counting 


counting 








immediately 












high 








3 




1) Disables 












counting 


Initiates 


Enables 








2) Sets output 


counting 


counting 








immediately 












high 








4 




Disables 
counting 





Enables 
counting 




5 




1 


Initiates 
counting 






Figure 4. Gate Pin Operations Summary 
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MODE 



MODE 3 



clock jTjTjTjTjTjTjTjTrLn_rLn_n_ 



WRn 1 


I 


4 


1 

3 

1 


2 


1 

1 

1 












OUTPUT (INTERRUPT) 


V" 








(n = 4) 
1 


1 . 


1 












1 
1 




i 
i 




WR m | 




1 




i 
i 










GATb 




5 


ll 

4 


1 i 

3 

1 


2 1 








I 


OUTPUT (INTERRUPT) 


1 


1 



clock JTJTJTJTJTJTJTJTJTJT_nJ"l_n_ 

0(4) 3 2 1 0(4) 3 2 1 0(4) 3 2 1 



OUTPUT (n = 4) J~ 


4 


l 




r 


1 


1 1 




0(5) 


3 


2 


i 


0(5) 4 


3 2 1 0(5) 4 


3 


OUTPUT (n = 5) |~~ 






I 


_| 


1 1 








4 


3 2 


1 0(4) 3 2 1 




OUTPUT (n = 4) l_ 










l_ 


1 1 














RESET 


| 


J 









MODE 1 



MODE 4 



clock JXIXnjTJTJTJTJTJTJTJT_n_n_ 



4 3 2 10 

OUTPUT I T 



clock JTJTJTJTJTJTJTJlJTJT_nJT_rL 



WR I n=4 



4 3 2 10 



4 3 2 4 3 2 10 

OUTPUT I r 



LOAD n I n = 4 T 

GATE 
OUTPUT 



t r 



4 3 2 10 



MODE 2 



MODE 5 



clock JTlJTJXnJTJXriJTJTJTJTJTJXn_n_ 




0(3) 
OUTPUT (n = 3) "] f 



clock jijijnjnjijijijijTjTjn_n_n_ 



4 3 2 10 



OUTPUT (n = 4) 



OUTPUT (n = 4) 



4 3 4 3 2 10 



Figure 5. 8253 Timing Diagrams 
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8253 READ/WRITE PROCEDURE 

Write Operations 

The systems software must program each counter of the 
8253 with the mode and quantity desired. The program- 
mer must write out to the 8253 a MODE control word and 
the programmed number of count register bytes (1 or 2) 
prior to actually using the selected counter. 

The actual order of the programming is quite flexible. 
Writing out of the MODE control word can be in any 
sequence of counter selection, e.g., counter #0 does not 
have to be first or counter #2 last. Each counter's MODE 
control word register has a separate address so that its 
loading is completely sequence independent. (SCO, SC1) 

The loading of the Count Register with the actual count 
value, however, must be done in exactly the sequence 
programmed in the MODE control word (RLO, RL1). This 
loading of the counter's count register is still sequence 
independent like the MODE control word loading, but 
when a selected count register is to be loaded it must be 
loaded with the number of bytes programmed in the 
MODE control word (RLO, RL1). The one or two bytes to 
be loaded in the count register do not have to follow the 
associated MODE control word. They can be programmed 
at any time following the MODE control word loading as 
long as the correct number of bytes is loaded in order. 

All counters are down counters. Thus, the value loaded 
into the count register will actually be decremented. 
Loading all zeroes into a count register will result in the 
maximum count (2 16 for Binary or 10 4 for BCD). In MODE0 
the new count will not restart until the load has been 
completed. It will accept one of two bytes depending on 
how the MODE control words (RLO, RL1) are program- 
med. Then proceed with the restart operation. 



MODE Control Word 
Counter n 



LSB 



Count Register byte 
Counter n 



MSB 



Count Register byte 
Counter n 



Note: Format shown is a simple example of loading the 8253 and 
does not imply that it is the only format that can be used. 

Figure 6. Programming Format 



No. 1 
No. 2 
No. 3 
No. 4 

No. 5 
No. 6 

No. 7 

No. 8 
No. 9 





A1 


AO 


MODE Control Word 
Counter 


1 




MODE Control Word 
Counter 1 


1 




MODE Control Word 
Counter 2 


1 




Count Register Byte 
Counter 1 







Count Register Byte 
MSB Counter 1 







Count Register Byte 
Counter 2 


1 





Count Register Byte 
Counter 2 


1 





Count Register Byte 
LSB _ _ 
Counter 








Count Register Byte 
MSB « „ 
Counter 









Note: The exclusive addresses of each counter's count register make 
the task of programming the 8253 a very simple matter, and 
maximum effective use of the device will result if this feature 
is fully utilized. 

Figure 7. Alternate Programming Formats 
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Read Operations 

In most counter applications it becomes necessary to read 
the value of the count in progress and make a 
computational decision based on this quantity. Event 
counters are probably the most common application that 
uses this function. The 8253 contains logic that will allow 
the programmer to easily read the contents of any of the 
three counters without disturbing the actual count in 
progress. 

There are two methods that the programmer can use to 
read the value of the counters. The first method involves 
the use of simple I/O read operations of the selected 
counter. By controlling the AO, A1 inputs to the 8253 the 
programmer can select the counter to be read (remember 
that no read operation of the mode register is allowed AO, 
A1-11). The only requirement with this method is that in 
order to assure a stable count reading the actual operation 
of the selected counter must be inhibited either by 
controlling the Gate input or by external logicthat inhibits 
the clock input. The contents of the counter selected will 
be available as follows: 
first I/O Read contains the least significant byte (LSB). 

second I/O Read contains the most significant byte 
(MSB). 

Due to the internal logic of the 8253 it is absolutely 
necessary to complete the entire reading procedure. If two 
bytes are programmed to be read then two bytes must be 
read before any loading WR command can be sent to the 
same counter. 



Read Operation Chart 



A1 


AO 


RD 













Read Counter No. 





1 





Read Counter No. 1 


1 








Read Counter No. 2 


1 


1 





Illegal 



Reading While Counting 

In order for the programmer to read the contents of any 
counter without effecting or disturbing the counting 
operation the 8253 has special internal logic that can be 
accessed using simple WR commands to the MODE 
register. Basically, when the programmer wishes to read 
the contents of a selected counter "on the fly" he loads the 
MODE register with a special code which latches the 
present count value into a storage register so that its 
contents contain an accurate, stable quantity. The 
programmer then issues a normal read command to the 
selected counter and the contents of the latched register is 
available. 

MODE Register for Latching Count 

AO, A1 = 11 



D7 


D6 


D5 


D4 


D3 


D2 


D1 


DO 


SC1 


SCO 








X 


X 


X 


X 



SC1.SC0— specify counter to be latched. 

D5.D4 — 00 designates counter latching operation. 

X — don't care. 

The same limitation applies to this mode of reading the 
counter as the previous method. That is, it is mandatory to 
complete the entire read operation as programmed. 



CLK 
8085 


3MHz 




^2 


* 1.5MHz 




CLK 

8253-5 













*lf an 8085 clock output is to drive an 8253-5 clock input, it must be reduced to 2 MHz or less. 



Figure 8. MCS-85™ Clock Interface* 
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ABSOLUTE MAXIMUM RATINGS* 

Ambient Temperature Under Bias 0°Cto70°C 

Storage Temperature -65°Cto+150°C 

Voltage On Any Pin 

With Respect to Ground -0.5 V to +7 V 

Power Dissipation 1 Watt 



*COMMENT: Stresses above those listed'under "Absolute 
Maximum Ratings" may cause permanent damage to the 
device. This is a stress rating only and functional opera- 
tion of the device at these or any other conditions above 
those indicated in the operational sections of this specif i- 
cation is not implied. Exposure to absolute maximum- 
rating conditions for extended periods may affect device 
reliability. 



D.C. CHARACTERISTICS (T A = o°c to ?o°c 


; V CC = 5V 


±5%) 






SYMBOL 


PARAMETER 


MIN. 


MAX. 


UNITS 


TEST CONDITIONS 


V|L 


Input Low Voltage 


-0.5 


0.8 


V 




V| H 


Input High Voltage 


2.2 


V CC +.5V 


V 




Vol 


Output Low Voltage 




0.45 


V 


Note 1 


V H 


Output High Voltage 


2.4 




V 


Note 2 


IlL 


Input Load Current 




±10 


juA 


Vin = V C c to V 


'OFL 


Output Float Leakage 




±10 


PA 


VouT = V C c to 0V 


•cc 


Vcc Supply Current 




140 


mA 





Notel: 8253, | 0L = 1.6 mA; 8253-5, l OL = 2.2mA. 
Note 2: 8253, l 0H = -1 50 /iA; 8253-5, Iqh = -400 /iA. 



CAPACITANCE t a = 25°c ; v cc = gnd = ov 



Symbol 


Parameter 


Min. 


Typ. 


Max. 


Unit 


Test Conditions 


C|N 


Input Capacitance 






10 


pF 


fc= 1 MHz 


C|/o 


I/O Capacitance 






20 


pF 


Unmeasured pins returned to Vss 
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A.C. CHARACTERISTICS t a = o°c to 70°c ; v cc = 5.ov ±5%; gnd = ov 
Bus Parameters (Note 1) 
Read Cycle: 



SYMBOL 


PARAMETER 


8253 
MIN. MAX. 


8253-5 
MIN. MAX. 


UNIT 


*ar 


Address Stable Before READ 


50 




50 




ns 


tRA 


Address Hold Time for READ 


5 




5 




ns 


*RR 


READ Pulse Width 


400 




300 




ns 


*RD 


Data Delay From READl^l 




300 




200 


ns 


tDF 


READ to Data Floating 


25 


125 


25 


100 


ns 


Write Cycle: 


SYMBOL 


PARAMETER 


8253 
MIIM. MAX. 


8253-5 
MIN. MAX. 


UNIT 








50 




50 






tAW 


Address Stable Before WR ITE 


ns 


*WA 


Address Hold Time for WRITE 


30 




30 




ns 


tww 


WRITE Pulse Width 


400 




300 




ns 


tDW 


Data Set Up Time for WR ITE 


300 




250 




ns 


tWD 


Data Hold Time for WRITE 


40 




30 




ns 


*RV 


Recovery Time Between WR ITES 


1 




1 




ps 



Notes: 1. AC timings measured at Vqh = 2.2, Vol = u -8 

2. Test Conditions: 8253, C L = 1 0OpF ; 8253-5: C L =150pF. 



Write Timing: 



Ao-1, CS 



3t 



X 



'Li' 



X 



jc 



Read Timing: 



A -1. CS 



X 



=sj\z= 



DATA BUS;%^%|/? HIGH IMPEDANCE ^^^^ 



X 



7777777777777777777, 
HIGH IMPEDANCE 
■////(////////////(/ 



Input Waveforms for A.C. Tests: 

2.4 



0.45 




TEST POINTS 
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Clock and Gate Timing: 


SYMBOL 


PARAMETER 


8253 

MIN. MAX. 


8253-5 
MIN. MAX. 


UNIT 


tCLK 


Clock Period 


380 


dc 


380 


dc 


ns 


tp\/VH 


High Pulse Width 


230 




230 




ns 


tpWL 


Low Pulse Width 


150 




150 




ns 


*GW 


Gate Width High 


150 




150 




ns 


tGL 


Gate Width Low 


100 




100 




ns 


tGS 


Gate Set Up Time to CLKt 


100 




100 




ns 


tGH 


Gate Hold Time After CLKt 


50 




50 




ns 


tOD 


Output Delay From CLK4-I 1 ! 




400 




400 


ns 


tODG 


Output Delay From Gatei' 1 ' 




300 




300 


ns 



Note 1 : Test Conditions: 8253: C|_ = 1 OOpF; 8253-5: Cl = 1 50pF. 



/r% Jcz 



X 






,r~\ 



M 
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PROGRAMMABLE INTERRUPT CONTROLLER 



a MCS-85™ Compatible 8259-5 
□ 8-Level Priority Controller 
d Expandable to 64 Levels 
a Programmable Interrupt Modes 



□ Individual Request Mask Capability 
a Single + 5V Supply (No Clocks) 
a 28-Pin Dual In-Line Package 



The Intel® 8259 handles up to 8 vectored priority interrupts for the CPU. It is cascadable for up to 64 vectored priority 
interrupts, without additional circuitry. It will be packaged in a 28-pin plastic DIP, uses nMOS technology and requires 
a single +5V supply. Circuitry is static, requiring no clock input. 

The 8259 is designed to minimize the software and real time overhead in handling multi-level priority interrupts. It has 
several modes, permitting optimization for a variety of system requirements. 



PIN CONFIGURATION 



BLOCK DIAGRAM 



csC 

wrC 
rdC 

° 5 C 
D 2 C 

D,r: 

CASOC 
CAS1 C 

gndC 



1 ^^ 


28 


=lVcc 


2 


27 


U*0 


3 


26 


JlNTA 


4 


25 


HIR7 


5 


24 


I]IR6 


6 


23 


HlR5 


7 8259 

8 


22 
21 


HIR4 
J|R3 


9 


20 


HIR2 


10 


19 


HIR1 


11 


18 


UlRO 


12 


17 


J INT 


13 


16 


U§P 


14 


15 


I] CAS 2 


PIN NAMES 





D 7- D 


DATA BUS (BIDIRECTIONAL) 


RD 


READ INPUT 


WR 


WRITE INPUT 


A 


COMMAND SELECT ADDRESS 


cs 


CHIP SELECT 


CAS1-CAS0 


CASCADE LINES 


SP 


SLAVE PROGRAM INPUT 


INT 


INTERRUPT OUTPUT 


INTA 


INTERRUPT ACKNOWLEDGE INPUT 


IR0-IR7 


INTERRUPT REQUEST INPUTS 




READ/ 
WRITE 
LOGIC 



CASO -•- 
CAS1 •«- 
CAS 2 •*- 



CASCADE 

BUFFER/ 

COMPARATOR 



SP- 



CONTROL LOGIC 



SERVICE 
REG 
HSR] 



PRIORITY 
RESOLVER 



o 



INTERRUPT 

REQUEST 

REG 

(IRRI 



-IR2 
-IR3 
-IR4 
-IR5 
-IR6 
-IR7 



INTERRUPT MASK REG 
(IMRI 



"INTERNAL BUS 



© Intel Corporation, 1978 
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INTRODUCTION TO THE USE OF INTER- 
RUPTS IN MICROCOMPUTER SYSTEMS 

Microcomputer system design requires that I/O devices 
such as keyboards, displays, sensors and other com- 
ponents receive servicing in an efficient method so that 
large amounts of the total system tasks can be assumed by 
the microcomputer with little or no effect on throughput. 

The most common method of servicing such devices is the 
Polled approach. This is where the processor must test 
each device in sequence and in effect "ask" each one if it 
needs servicing. It is easy to see that a large portion of the 
main program is looping through this continuence polling 
cycle and that such a method would have a serious, 
detrimental effect on system throughput thus limiting the 
tasks that could be assumed by the microcomputer and 
reducing the cost effectiveness of using such devices. 

A more desireable method would be one that would allow 
the microprocessor to be executing its main program and 
only stop to service peripheral devices when it is told to do 
so by the device itself. In effect, the method would provide 
an external asynchronous input that would inform the 
processor that it should complete whatever instruction 
that is currently being executed and fetch a new routine 
that will service the requesting device. Oncethis servicing 
is complete however the processor would resume exactly 
where it left off. 

This method is called Interrupt. It is easy to see that 
system throughput would drastically increase, and thus 
more tasks could be assumed by the microcomputer to 
further enhance its cost effectiveness. 

The Programmable Interrupt Controller (PIC) functions 
as an overall manager in an Interrupt-Driven system 
environment. It accepts requests from the peripheral 
equipment, determines which of the incoming requests is 
of the highest importance (priority), ascertains whether 
the incoming request has a higher priority value than the 
level currently being serviced and issues an Interrupt to 
the CPU based on this determination. 

Each peripheral device or structure usually has a special 
program or "routine" that is associated with its specific 
functional or operational requirements; this is referred to 
as a "service routine". The PIC, after issuing an Interrupt 
to the CPU, must somehow input information into the CPU 
that can "point" the Program Counter to the service 
routine associated with the requesting device. The PIC 
does this by providing the CPU with a 3-byte CALL 
instruction. 




<^Z^I '/o W) |- 
I I 

I i 



Figure 1. Polled Method 




Figure 2. Interrupt Method 
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FUNCTIONAL DESCRIPTION 

General 

The 8259 is a device specifically designed for use in real 
time, interrupt driven, microcomputer systems. It man- 
ages eight levels or requests and has built-in features for 
expandability to other 8259s (up to 64 levels). It is 
programmed by the system's software as an I/O 
peripheral. A selection of priority modes is available to the 
programmer so that the manner in which the requests are 
processed by the 8259 can be configured to match his 
system requirements. The priority modes can be changed 
or reconfigured dynamically at any time during the main 
program. This means that the complete interrupt structure 
can be defined as required, based on the total system 
environment. 

Interrupt Request Register (IRR) and rice 
In-Service Register (ISR) 

The interrupts at the IR input lines are handled by two 
registers in cascade, the Interrupt Request Register (IRR) 
and the In-Service Register (ISR). The IRR is used to store 
all the interrupt levels which are requesting service; and 
the ISR is used to store all the interrupt levels which are 
being serviced. 



0,-tn, 



DATA il K 



CASO 
CAS1 
CA52 



w 



REAO/ 
WRITE 
LOGIC 



CASCADE 
BUFFER* 
COMPA- 
RATOR 





INTA 

1 




INT 

! 






CONTROL LOGIC 












■' 


■ 





IE 



SERVICE 
REG 
(ISRI 



W 



c 



Y A 

RESOLVER \j- 



n 



INTERRUPT 

REQUEST 

REG 

(IRRI 



V 



INTERNAL BUS 



Priority Resolver 

This logic block determines the priorities of the bits set in 
the IRR. The highest priority is selected and strobed into 
the corresponding bit of the ISR during INTA pulse. 

INT (Interrupt) 

This output goes directly to the CPU interrupt input. The 
Voh level on this line is designed to be fully compatible 
with the 8080 input level. 



INTA (Interrupt Acknowledge) 

Three INTA pulses will cause the 8259 to release a 3-byte 
CALL instruction onto the Data Bus. 

Interrupt Mask Register (IMR) 

The IMR stores the bits of the interrupt lines to be masked. 
The IMR operates on the ISR. Masking of a higher priority 
input will not affect the interrupt request lines of lower 
priority. 



Figure 5. 8259 Block Diagram Showing Basic Interrupt 
Functions 



ADDRESS BUS (16) 



CASCADE 
LINES 



CONTROL BUS 



Y\ 



<> * * 



CS" A. D 7 -D„ RD WR INT INTA 

CASO ^ 



CAS 2 IRQ IRQ IRQ IRQ IRQ IRQ IRQ IRQ 

SP 76543210 

— n 



SLAVE 
PROG. 



INTERRUPT 
REQUESTS 



Figure 6. 8259 Interface to Standard System Bus 
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Data Bus Buffer 

This 3-state, bi-directional, 8-bit buffer is used to interface 
the 8259 to the system Data Bus. Control words and status 
information are transferred through the Data Bus Buffer. 

Read/Write Control Logic 

The function of this block is to accept OUTput commands 
from the CPU. It contains the Initialization Command 
Word (ICW) registers and Operation Command Word 
(OCW) registers which store the various control formats 
for device operation. This function block also allows the 
status of the 8259 to be transferred onto the Data Bus. 

CS (Chip Select) 

A "low" on this input enables the 8259. No reading or 
writing of the chip will occur unless the device is selected. 

WR (Write) 

A "low" on this input enables the CPU to write control 
words (ICWs and OCWs) to the 8259. 

RD (Read) 

A "low" on this input enables the 8259 to send the status of 
the Interrupt Request Register (IRR), In Service Register 
(ISR), the Interrupt Mask Register (IMR) ortheBCDof the 
Interrupt level on to the Data Bus. 

Ao _ _ 

This input signal is used in conjunction with WR and RD 
signals to write commands into the various command 
registers as well as reading the various status registers of 
the chip. This line can be tied directly to one of the address 
lines. 



<V>0 
A — ^ 

Yv 



DATA 

BUS 

BUFFER 






READ/ 
WRITE 
LOGIC 



CASCADE 

BUFFER/ 
COMPA- 
RATOR 





INTA 

1 


ir 


T 






CONTROL LOGIC 



















in 



F CC 

REG 
(ISR) 



A- PRIORITY /' 
\p RESOLVES N^ 



n 



INtERflUPt 

REQUEST 

REG 

(IRfli 



P INTERRUPT VASKHE'i 

(IMR) 



INTERNAL BUS 



Figure 3. 8259 Block Diagram Showing Data Bus Buffer 
and Read/Write Logic Functions 





Ao 


D 4 


D 3 


RD 


WR 


CS 


INPUT OPERATION (READ) 












1 





IRR, ISR or Interrupting Level => DATA BUS (Note 1) 


1 









1 





IMR => DATA BUS 


OUTPUT OPERATION (WRITE) 











1 








DATA BUS =*OCW2 








1 


1 








DATA BUS =>OCW3 





1 


X 


1 








DATA BUS => ICW1 


1 


X 


X 


1 








DATA BUS=>OCW1, ICW2, ICW3 (Note 2) 


DISABLE FUNCTION 


X 


X 


X 


1 


1 





DATA BUS =* 3-STATE 


X 


X 


X 


X 


X 


1 


DATA BUS =*• 3-STATE 



Notel: Selection of IRR, ISR or Interrupting Level is based on the content of OCW3 written before the READ operation. 
Note 2: On-chip sequencer logic queues these commands into proper sequence. 



Figure 4. 8259 Basic Operation 
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SP (Slave Program) 

More than one 8259 can be used in the system to expand 
the priority interrupt scheme up to 64 levels. In such case, 
one 8259 acts as the master, and the others act as slaves. A 
"high" on the SP pin designates the 8259 as the master, a 
"low" designates it as a slave. 

The Cascade/Buffer/Comparator 

This function block stores and compares the IDs of all 
8259 used in the system. The associated three I/O pins 
(CASO-2) are outputs when the 8259 is used as a master 
( SP = 1), and are inputs when the 8259 is used as a slave 
(SP = 0). As a master, the 8259 sends the ID of the 
interrupting slave device onto the CASO-2 lines. The slave 
thus selected will send its preprogrammed subroutine 
addre ssed onto the Data Bus during next two consecutive 
INTA pulses. (See section "Cascading the 8259".) 



w 



DATA 

BUS 

BUFFER 






WEADB 
V.KI1E 
LOGIC 




CONTROL LOGIC 

: 1 



n 



SERVICE 
REG 
(ISR) 



a A 

A- r-Iii-WTY / 

\ r SESOLVER\,- 



n 



tNTSRRUPT 

BEQUEST 

REG 



A N INTERRUPT MASK REG 



INTERNAL BUS 



Figure 7. 8259 Block Diagram Showing Cascading 
Function 



3. The C PU acknowledges the INT and responds with an 
INTA pulse. 



4. Upon receiving an INTA from the CPU group, the 
highest priority ISR bit is set, and the corresponding 
IRR bit is reset. The 8259 will also release a CALL 
instruction code (11001101) onto the 8-bit Data Bus 
through its D7-0 pins. 

5. This CALL instruction will initiate two more INTA 
pulses to be sent to the 8259 from the CPU group. 

6. These two INTA pulses allow the 8259 to release its 
preprogrammed subroutine address onto the Dat a Bus. 
The lower 8-bit address is released at the first INTA 
pulse a nd the higher 8-bit address is released at the 
second INTA pulse. 

7. This completes the 3-byte CALL instruction released 
by the 8259. ISR bit is not reset until the end of the 
subroutine when an EOI (End of interrupt) command is 
issued to the 8259. 

Programming The 8259 

The 8259 accepts two types of command words generated 
by the CPU: 

1. Initialization Command Words (ICWs): 

Before normal operation can begin, each 8259 in the 
system must be brought to a starti ng p oint — by a 
sequence of 2 or 3 bytes timed by WR pulses. This 
sequence is described in Figure 1. 

2. Operation Command Words (OCWs): 

These are the command words which command the 
8259 to operate in various interrupt modes. These 
modes are: 

a. Fully nested mode 

b. Rotating priority mode 

c. Special mask mode 

d. Polled mode 

The OCWs can be written into the 8259 at anytime after 
initialization. 
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OPERATIONAL DESCRIPTION 

General 

The powerful features of the 8259 in a microcomputer 
system are its programmability and its utilization of the 
CALL instruction to jump intoBny address in the memory 
map. The normal sequence of events that the 8259 
interacts with the CPU is as follows: 

1. One or more of the INTERRUPT REQUEST lines (IR7- 
0) are raised high, setting the corresponding IRR bit(s). 

2. The 8259 accepts these requests, resolves the 
priorities, and sends an INT to the CPU. 





YES 




(S = 


NO 










1 


S7 


S 6 


s 5 


S4 


S3 


s 2 


Si 


s 


















READY TO ACCEPT REQUESTS 
IN THE FULLY NESTED MODE 





Figure 8. Initialization Sequence 
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Initialization Command Words 1 and 2 (ICW1 and 
ICW2) 

Whenever a command is issued with A0 = and D4 = 1,this 
is interpreted as Initialization Command Word 1 (ICW1), 
and initiates the initialization sequence. During this 
sequence, the following occur automatically: 

a. The edge sense circuit is reset, which means that 
following initialization, an interrupt request (IR) 
input must make a low to high transition to generate 
an interrupt. 

b. The interrupt Mask Register is cleared. 

c. IR 7 input is assigned priority 7. 

d. Special Mask Mode Flip-flop and status Read Flip- 
flop are reset. 

The 8 requesting devices have 8 addresses equally spaced 
in memory. The addresses can be programmed at 
intervals of 4 or 8 bytes; the 8 routines thus occupying a 
page of 32 or 64 bytes respectively in memory. 

The address format is: 



AO-4 are automatically inserted by the 8259, while A15-6 
are programmed by ICW1 and ICW2. When interval = 8, A5 
is fixed by the 8259. If interval = 4, A5 is programmed in 
ICW1. Thus, the interrupt service routines can be located 
anywhere in the memory space. The 8 byte interval will 
maintain compatibility with current 8080 RESTART 
instruction software, while the 4 byte interval is best for 
compact jump table. 

The address format inserted by the 8259 is described in 
Table 1. 

The bits F and S are defined by ICW1 as follows: 

F: Call address interval. F = 1, then interval =4; F = 0, 

then interval = 8. 

S: Single. S = 1 means that this is the only 8259 in the 
system. It avoids the necesity of programming ICW3. 
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DO 
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A6 
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A6 
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IR 5 


A7 


A6 


A5 1 1 


A7 A6 1 1 











IR 4 


A7 


A6 


A5 1 


A7 A6 1 











IR 3 


A7 


A6 


A5 1 1 


A7 A6 1 1 











IR 2 


A7 


A6 


A5 1 


A7 A6 1 











IR 1 


A7 


A6 


A5 1 


A7 A6 1 











IR 


A7 


A6 


A5 


A7 A6 












Table 1. 8259 Address Format 
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Example of Interrupt Acknowledge Sequence 

Assume the 8259 is programmed with F = 1 (CALL address 
interval = 4), and IR5 is the interrupting le vel. Th e 3 byte 
sequence released bythe8259timed bythe INTApulsesis 
as follows: 





D7 


D6 


D5 


D4 


D3 


D2 


D1 


DO 




1st INTA 


1 


1 








1 


1 





1 


CALL 
CODE 


2nd INTA 


A7 


A6 


A5 


1 





1 








LOWER 

ROUTINE 

ADDRESS 


3rd INTA 


A15 


A14 


A13 


A12 


A11 


A10 


A9 


A8 


HIGHER 

ROUTINE 

ADDRESS 



Initialization Command Word 3 (ICW3) 

This will load the 8-bit slave register. The functions of this 
register are as follows: 

a. If the 8259 is the master, a "1" is set for each slave in 
the system. The master then will release byte 1 of the 
CALL sequence and will enable the corresponding 
slave to release bytes 2 and 3, through the cascade 
lines. 

b. If the 8259 is a slave, bits 2-0 identify the slave. The 
slave compares its CASO-2 inputs (sent by the 
master) with these bits. If they are equal, bytes 2 and 
3 of the CALL sequence are released. 

If bit S is set in ICW1, there is no need to program ICW3. 



A o 


D 


7 


D 


6 


°5 


°4 


D 3 


c 


2 


C 


1 


D o 







A 7 


A 6 


A 5 


1 





F 


s 













































1 = SINGLE 

0= NOT SINGLE 


















CALL ADDRESS INTERVAL 
1 = INTERVAL IS 4 
= INTERVAL IS 8 


















A 7 _ 5 OF LOWER 
ROUTINE ADDRESS 





























A 


D 


7 


C 


6 


°5 


c 


4 


D 


3 


D 2 


c 


, 


D 






1 


A ,5 


A » 


A 13 


A 12 


A n 


A 10 


A 9 


A 8 
































UPPER ROUTINE 
ADDRESS 







































ICW3 (MASTER DEVICE) 
Dj D 4 D 3 D 2 



1 


S 7 


S 6 


S5 


S 4 


S 3 


s 2 


S, 


s 


































1 




IR INPUT HAS A SLAVE 
IR INPUT DOES NOT HAVE 
A SLAVE 





































*0 


°7 


°6 


ICW3 (SLAVE DEVICEI 
Dj D 4 D 3 D 2 


D 


1 


D 







1 

















ID 2 


ID, 


ID 






I 

X 

I 


I 

X 

I 


I I 














> 


( X X 
I I 






SLAVE IDI1I 



























1 


2 


3 


4 


5 


6 


7 









1 





1 





1 





1 




DON'T 
CARE 


















1 


1 








1 


1 


























1 


1 


1 


1 





















NOTE 1: SLAVE ID IS EQUAL TO THE CORRESPONDING MASTER IR INPUT. 



Figure 9. Initialization Command Word Format 
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Operation Command Words (OCWs) 

After the Initialization Command Words (ICWs) are 
programmed into the 8259, the chip is ready to accept 
interrupt requests at its input lines. However, during the 
8259 operation, a selection of algorithms can command 
the 8259 to operate in various modes through the 
Operation Command Words (OCWs). These various 
modes and their associated OCWs are described below. 

Interrupt Masks 

Each Interrupt Request input can be masked individually 
by the Interrupt Masked Register (IMR) programmed 
through OCW1. 

The IMR operates on the In-Service Register. Note that if 
an interrupt is already acknowledged by the 8259 (an INTA 
pulse has occurred), then the Interrupting level, although 
masked, will inhibit the lower priorities. To enable these 
lower priority interrupts, one can do one of two things: (1) 
Write an End of Interrupt (EOI) command (OCW2) to reset 
the ISR bit or (2) Set the special mask mode using OCW3 
(as will be explained later in the special mask mode.) 

Fully Nested Mode 

The 8259 will operate in the fully nested mode after the 
execution of the initialization sequence without any OCW 
being written. In this mode, the interrupt requests are 
ordered in priorities from Othrough 7. When an interrupt is 
acknowledged, the highest priority request is determined 
and its address vector placed on the bus. In addition, a bit 
of the Interrupt service register (IS 7-0) is set. This bit 
remains set until the CPU issues an End of Interrupt (EOI) 
command immediately before returning from the service 
routine. While the IS bit is set, all further interrupts of lower 
priority are inhibited, while higher levels will be able to 
generate an interrupt (which will only be acknowledged if 
the CPU has enabled its own interrupt input through 
software). 

After the Initialization sequence, IRO has the highest 
priority and IR7 the lowest. Priorities can be changed, as 
will be explained in the rotating priority mode. 

Rotating Priority Commands 

There are two variations of rotating priority: auto rotate 
and specific rotate. 

1. Auto Rotate — Executing the Rotate-at-EOI (Auto) 
command, resets the highest priority ISR bit and 
assigns that input the lowest priority. Thus, a device 
requesting an interrupt will have to wait, in the worst 
case, until 7 other devices are serviced at most once 
each, i.e., if the priority and "in-service" status is: 

BEFORE ROTATE IS7 IS6 IS5 IS4 IS3 IS2 IS1 ISO 



AFTER ROTATE IS7 IS6 IS5 IS4 IS3 IS2 IS1 ISO 



"IS" STATUS 



PRIORITY STATUS 






1 





1 














LOWEST PRIORITY 




HIGHEST PRIORITY 


7 


6 


5 


4 


3 


2 


1 









1 




















LOWEST PRIORITY 




HIGHEST PRIORITY 


4 


3 


2 


1 





7 


6 


5 



PRIORITY STATUS 



In this example, the In-Service FF corresponding to 
line 4 (the highest priority FF set) was reset and line 4 
became the lowest priority, while all the other priorities 
rotated correspondingly. 

The Rotate command is issued in OCW2, where: R = 
1, EOI - 1, SEOI =0. 

2. Specific Rotate — The programmer can change 
priorities by programming the bottom priority, and by 
doing this, to fix the highest priority: i.e., if IR5 is 
programmed as the bottom priority device, the IR6 will 
have the highest one. This command can be used with 
or without resetting the selected ISR bit. 

The Rotate command is issued in OCW2 where: R = 1, 
SEOI = 1. L2, L1, L0 are the BCD priority level codes of the 
bottom priority device. If EOI = 1 also, the ISR bit selected 
by L2-L0 is reset. 

Observe that this mode is independent of the End of 
Interrupt Command and priority changes can be 
executed during EOI command or independently from 
the EOI command. 

End of Interrupt (EOI) and Specific End of 
Interrupt (SEOI) 

An End of Interrupt command word must be issued to the 
8259 before returning from a service routine, to reset the 
appropriate IS bit. 

There are two forms of EOI command: Specific and non- 
specific. When the 8259 is operated in modes which 
preserve the fully nested structure, it can determine which 
IS bittoreseton EOI. When anon-Specific EOI command 
is issued the 8259 will automatically reset the highest IS 
bit of those that are set, since in the nested mode, the 
highest IS level was necessarily the last level acknowl- 
edged and will necessarily be the next routine level 
returned from. 

However, when a mode is used which may disturb the fully 
nested structure, such as in the rotating priority case, the 
8259 may no longer be able to determine the last level 
acknowledged. In this case, a specific EOI (SEOI) must be 
issued which includes the IS level to be reset as part of the 
command. The End of the Interrupt is issued whenever 
EOI = "1" in OCW2. Forspecific EOI, SEOI = "1",and EOI = 
1 . L2, L1 , L0 is then the BCD level to be reset. As explained 
in the Rotate Mode earlier, this can also be the bottom 
priority code. Note that although the Rotate command can 
be issued during an EOI = 1, it is not necessarily tied to it. 
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1 


M7 


M6 


M5 


M4 


M3 


M2 


M1 


MO 






























INTERRUPT MASK 
1 - MASK SET 
= MASK RESET 








































R 


SEOI 


EOI 








L 2 


Li 


L o 










































BCD LEVEL TO BE RESET 
OR PUT INTO LOWEST PRIORITY 













1 


2 


3 


4 


5 


6 


7 









1 





1 





1 





1 




















1 


1 








1 


1 


























1 


1 


1 


1 






























NON-SPECIFIC END OF INTERRUPT 
1 = RESET THE HIGHEST PRIORITY 

BIT OF ISR 
= NO ACTION 


















SPECIFIC END OF INTERRUPT 
1 = L 2 ,L,,L BITS ARE USED 
= NO ACTION 


















ROTATE PRIORITY 




































c 


- NOT ROTATE 









ESMM SMM 



P ERIS RIS 



READ IN-SERVICE REGISTER 



READ 
IR REG 
ON NEXT 
RD PULSE 



READ 
IS REG 
ON NEXT 
RD PULSE 



A HIGH ENABLES THE NEXT RD PULSE 
TO READ THE BCD CODE OF THE HIGH- 
EST LEVEL REQUESTING INTERRUPT. 



SPECIAL MASK MODE 



RESET 

SPECIAL 

MASK 



SET 

SPECIAL 

MASK 



Figure 10. Operation Command Word Format 
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Special Mask Mode (SMM) 

This mode is useful when some bit(s) are set (masked) by 
the Interrupt Mask Register (IMR) through OCW1. If, for 
some reason, we are currently in an interrupt service 
routine which is masked (this could happen when the 
subroutine intentionally mask itself off), it is still possible 
to enable the lower priority lines by setting the Special 
Mask mode. In this mode the lower priority lines are 
enabled until the SMM is reset. The higher priorities are 
not affected. 

The special mask mode FF is set by OCW3 where ESMM = 
1, SMM = 1, and reset where: ESSM = 1 and SMM = 0. 

Polled Mode 

In this mode, the CPU must disable its interrupt input. 
Service to device is achieved by programmer initiative by a 
Poll command. 

The poll command is issued by setting P = "1" in OCW3 
during a WR pulse. 

The 8259 treats the next RD pulse as an interrupt 
acknowledge, sets the appropriate IS Flip-flop, if there is a 
request, and reads the priority level. 

For polling operation, an OCW3 must be written before 
every read. 



The word enabled onto the data bus during RD is: 

D7 D6 D5 D4 D3 D2 D1 DO 



I 


- 


- 


- 


- 


W2 


W1 


WO 



WO — 2: BCD code of the highest priority level 
requesting service. 
I: Equal to a "1" if there is an interrupt. 

This mode is useful if there i s a ro utine common to 
several levels — so that the INTA sequence is not 
needed (and this saves ROM space). Another 
application is to use the poll mode to expand the 
number of priority levels to more than 64. 





A0 D4 D3 








OCW1 


1 


M7-M0 


IMR (Interrupt Mask Register). WR will load it while status can be 










read with RD. 


OCW2 





R SEOI 


EOI 














No Action. 









1 


Non-specific End of Interrupt. 






1 





No Action. 






1 


1 


Specific End of Interrupt. L2, L1, L0 is the BCD level to be reset. 






1 





No Action. 






1 


1 


Rotate priority at EOI. (Auto Mode) 






1 1 





Rotate priority, L2, L1, L0 becomes bottom priority without 
Ending of Interrupt. 






1 1 


1 


Rotate priority at EOI (Specific Mode), L2, L1, L0 becomes 
bottom priority, and its corresponding IS FF is reset. 


OCW3 


1 


ESMM 


SMM 


r Special Mask not Affected. 











1 






1 





Reset Special Mask. 






1 


1 


Set Special Mask. 






ERIS 


RIS 










1 



1 



h No Action. 

Read IR Register Status. 






1 


1 


Read IS Register Status. 



Note: The CPU interrupt input must be disabled during: 

1. Initialization sequence for all the 8259 in the system. 

2. Any control command execution. 



Figure 11. Summary of Operation Word Programming 
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Reading 8259 Status 

The input status of several internal registers can be read 
to update the user information on the system. The 
following registers can be read by issuing a suitable 
OCW3 and reading with RD. 

Interrupt Requests Register (IRR): 8-bit register which 
contains the levels requesting an interrupt to be 
acknowledged. The highest request level is reset from the 
IRR when an interrupt is acknowledged. (Not affected by 
IMR). 

In Service Register (ISR): 8-bit register which contains 
the priority levels that are being serviced. The ISR is 
updated when an End of Interrupt command is issued. 

Interrupt Mask Register: 8-bit register which contains the 
interrupt request lines which are masked. 

The IRR can be read when prior to the RD pulse, an WR 
pulse is issued with OCW3, and ERIS = 1, RIS = 0. 
The ISR can be read in a similar mode, when ERIS = 1, RIS 
= 1. 

There is no need to write an OCW3 before every status 
read operation as long as thestatus read corresponds with 
the previous one, i.e. the 8259 "remembers" whether the 
IRR or ISR has been previously selected by the OCW3. 

For readingjhe IMR, a WR pulse is not necessary to 
preceed the RD. The output data bus will contain the IMR 
whenever RD is active and A0 = 1. 

Polling overrides status read when P = 1, ERIS = 1 in 
OCW3. 



Cascading 

The 8259 can be easily interconnected in a system of one 
master with up to eight slaves to handle up to 64 priority 
levels. 

A typical system is shown in Figure 12. The master con- 
trols, through the 3 line cascade bus, which one of the 
slaves will release the corresponding address. 

As shown in Figure 12, the slaves interrupt outputs are 
connected to the master interrupt request inputs. When a 
slave request line is activated and later acknowledge d, the 
master releases the 8080 CALL code duri ng the first INTA 
pulse. From the trailing edge of this first INTA pulse until 
the trailing edge of the third pulse, the CAS lines will 
contain the slave address code. Thus, the corresponding 
slave is enabled to release the two- byte se rvice routine 
address during the second and third INTA pulses. 

Note that since the CAS lines default to 000, no slave 
should be connected with IRO on the master unless ah 
other master request inputs (IR1-IR7) are connected to 
slaves. Otherwise, the slave on IRO will attempt to drive the 
data bus in conflict with a non-slave interrupt request on 
the master. 

It is obvious that each 8259 in the system must follow a 
separate initialization sequence and can be programmed 
to work in a different mode. An EOI command must be 
issued twice: once for the master and once for the 
corresponding slave. An address decoder is required to 
activate the Chip Select (CS) input of each 8259. The slave 
program pin (SP) must be at a "low" level for a slave ( and 
then the cascade lines are inputs) and at a "high" level for a 
master (and then the cascade lines are outputs). 



ADDRESS BUS (16) 



CONTROL BUS 



7\ 



7\ 



iz iz 



7> 



Sz iz 



CAS0 

8259 CAS , 

SLAVE A 

CAS 2 

SP76543210 



7 6 5 4 3 2 10 



\z iz 



CAS 2 
SP76543210 



5 4 3 2 10 



CS A 
CAS0 



CAS 2 

SP M7 M6 M5 M4 M3 M2 M1 M0 



m 



3 2 10 



INTERRUPT REQUESTS 



Figure 12. Cascading the 8259 
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INST. 
NO. 



AO D7 D6 D5 D4 D3 D2 D1 DO OPERATION DESCRIPTION 



1 
2 
3 
4 
5 
6 
7 
8 
9 

10 

11 

12 

13 
14 
15 
16 
17 
18 



ICW1 A 
ICW1 B 
ICW1 C 
ICW1 D 
ICW2 
ICW3M 
ICW3S 
OCW1 
OCW2E 

OCW2SE 

OCW2RE 

OCW2 RSE 

OCW2 RS 
OCW3P 
OCW3RIS 
OCW3RR 
OCW3 SM 
OCW3 RSM 



A7 A6 A5 1 

A7 A6 A5 1 

A7 A6 A5 1 

A7 A6 A5 1 



1 1 

1 

1 





A15 A14 A13 A12 A11 A10 A9 

S7 S6 S5 S4 S3 S2 S1 

S2 S1 

M7 M6 M5 M4 M3 M2 M1 

10 




1 



L2 L1 




1 







Notes: 

1. In the master mode SP pin = 1, in slave mode SP = 0. 

2. (— ) = do not care. 








A8 
SO 
SO 
MO 


LO 





L2 L1 LO 



1 











L2 


L1 


LO 













1 






















1 


1 
















1 





1 


1 
















1 




















Byte 1 initialization, format = 4, single. 

Byte 1 initialization, format = 4, not single. 

Byte 1 initialization, format = 8, single. 

Byte 1 initialization, format = 8, not single. 

Byte 2 initialization (Address No. 2) 

Byte 3 initialization — master. 

Byte 3 initialization — slave. 

Load mask reg, read mask reg. 

Non specific EOI. 

Specific EOI. L2, L1, LO code of IS FF 

to be reset. 
Rotate at EOI (Auto Mode). 
Rotate at EOI (Specific Mode). L2, L1, LO, 

code of line to be reset and selected as 

bottom priority. 
L2, L1, LO code of bottom priority line. 
Poll mode. 
Read IS register. 
Read requests register. 
Set special mask mode. 
Reset special mask mode. 



Figure 13. 8259 Instruction Set 



7-116 



8259/8259-5 



ABSOLUTE MAXIMUM RATINGS' 



Ambient Temperature Under Bias 0°Cto70°C 

Storage Temperature -65°Cto+150°C 

Voltage On Any Pin 

With Respect to Ground -0.5Vto+7V 

Power Dissipation 1 Watt 



'COMMENT: 

Stresses above those listed under "Absolute Maximum Ratings" 
may cause permanent damage to the device. This is a stress rating 
only and functional operation of the device at these or any other 
conditions above those indicated in the operational sections of this 
specification is not implied. 



D.C. CHARACTERISTICS 

(T A = 0°C to 70°C; V cc = 5V ±5%) 



SYMBOL 


PARAMETER 


MIN. 


MAX. 


UNITS 


TEST CONDITIONS 


V|L 


Input Low Voltage 


-.5 


.8 


V 




VlH 


Input High Voltage 


2.0 


V CC +-5V 


V 




Vol 


Output Low Voltage 




.45 


V 


l L = 2 mA 


Voh 


Output High Voltage 


2.4 




V 


I OH = -400/iA 


V OH-INT 


Interrupt Output High Voltage 


2.4 
3.5 




V 
V 


I OH =-400juA 
I OH = -50 juA 


'iLdRo^) 


Input Leakage Current 
for IRo-7 




-300 
10 


MA 
MA 


V| N = 0V 

V|N = Vcc 


IlL 


Input Leakage Current 
for Other Inputs 




10 


[xA 


V|N = V C c to 0V 


( OFL 


Output Float Leakage 




±10 


MA 


Vqut = 0.45V to V CC 


'cc 


Vcc Supply Current 




100 


mA 





CAPACITANCE 

T A = 25°C; V cc = GND = 0V 



SYMBOL 


PARAMETER 


MIN. 


TYP. 


MAX. 


UNIT 


TEST CONDITIONS 


C IN 


Input Capacitance 






10 


pF 


fc= 1 MHz 


c i/o 


I/O Capacitance 






20 


pF 


Unmeasured pins returned to Vgs 



7-117 



8259/8259-5 



A.C. CHARACTERISTICS 

(T A = 0°C to 70° C; V CC = +5V ±5%, GND = 0V) 

Bus Parameters 
Read: 



SYMBOL 


PARAMETER 


8259 
MIN. MAX. 


8259-5 
MIN. MAX. 


UNIT 


*AR 


CS/A Stable Before RD or INTA 


50 




50 




ns 


*RA 


CS/Aq Stable After RD or INTA 


5 




30 




ns 


*RR 


RD Pulse Width 


420 




300 




ns 


*RD 


Data Valid From RD/TNTAm 




300 




200 


ns 


tDF 


Data Float After RD/INTA 


20 


200 


20 


100 


ns 


Write: 


SYMBOL 


PARAMETER 


8259 

MIN. MAX. 


8259-5 
MIN. MAX. 


UNIT 


X MN 


A Stable Before WR 


50 




50 




ns 


*WA 


A Stable After WR 


20 




30 




ns 


tyvw 


WR Pulse Width 


400 




300 




ns 


tDW 


Data Valid to WR (T.E.) 


300 




250 




ns 


tWD 


Data Valid After WR 


40 




30 




ns 


Other Timings: 


SYMBOL 


PARAMETER 


82 

MIN. 


59 

MAX. 


825 
MIN. 


9-5 

MAX. 


UNIT 


t|W 


Width of Interrupt Request Pulse 


100 




100 




ns 


t|NT 


INT t After IR t 


400 




350 




ns 


tic 


Cascade Line Stable After INTA t 


400 




400 




ns 



Note 1: 8259: C L = 100pF, 8259-5: Ci_ = 150pF. 



Input Waveforms for A.C. Tests 



2.4 



0.45 




2.2 2.2 

J> TEST POINTS <^ 
0.8 0.8 
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WAVEFORMS 



Read Timing 



CHIP SELECT 



\ 



ADDRESS BUS 



X 



'sj^z* 



i bus \ \\ Vhigh impedance \\ \ ^ 



J 



X 



[> -T Rfl 



\^^ 



Write Timing 



ADDRESS BUS 



\ 



Taw- 



X 



r i 



f 



X 



X 



v^ 



Other Timing 



/ 



"Y 



NTA \ © / f 

DB \ \\ HIGH IMPEDANCE \\\^ 



V^7 \ ® / 

KVWWW^ |A\\\\\V| |AV 



'ic r"~ 



Note: Interrupt Request must remain "HIGH" (at least) until leading edge of first INTA. 



Read Status/Poll Mode 



\ 



J V. 



y 



v_ 


/ 










\_ 


/ 








V////////// 


OCW3 >//////////////, 


DATA >//////////////, 
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PROGRAMMABLE KEYBOARD/DISPLAY INTERFACE 



□ MCS-85™ Compatible 8279-5 

a Simultaneous Keyboard Display 
Operations 

□ Scanned Keyboard Mode 
a Scanned Sensor Mode 

q Strobed Input Entry Mode 
d 8-Character Keyboard FIFO 

□ 2-Key Lockout or N-Key Rollover with 
Contact Debounce 



d Dual 8- or 16-Numerical Display 
b Single 16-Character Display 

□ Right or Left Entry 16-Byte Display 
RAM 

□ Mode Programmable from CPU 
a Programmable Scan Timing 

d Interrupt Output on Key Entry 



The Intel® 8279 is a general purpose programmable keyboard and display I/O interface device designed for use with 
Intel® microprocessors. The keyboard portion can provide a scanned interface to a 64-contact key matrix. The 
keyboard portion will also interface to an array of sensors or a strobed interface keyboard, such as the hall effect and 
ferrite variety. Key depressions can be 2-key lockout or N-key rollover. Keyboard entries are debounced and strobed in 
an 8-character FIFO. If more than 8 characters are entered, overrun status is set. Key entries set the interrupt output 
line to the CPU. 

The display portion provides a scanned display interface for LED, incandescent, and other popular display 
technologies. Both numeric and alphanumeric segment displays may be used as well as simple indicators. The 8279 
has 16X8 display RAM which can be organized into dual 16X4. The RAM can be loaded or interrogated by the CPU. Both 
right entry, calculator and left entry typewriter display formats are possible. Both read and write of the display RAM 
can be done with auto-increment of the display RAM address. 



PIN CONFIGURATION 



RLjC 

clkC 

IRQfJ 
RL 4 C 
RLsC 
RLslI 

RL 7 [[ 

RESET £ 

RDC 

wrC 

DB C 
DB,C 
DB 2 C 
DB 3 C 
DB 4 C 
DB 5 C 
DB 6 C 
DB 7 C 
VssC 



40 I]V CC 
39 D«L, 
38 I]RLo 
37 UCNTL/STB 
36 3 SHIFT 
35 HSL 3 
34 DSL 2 
33 HSL, 
32 DSLo 
31 UOUT B 
30 HOUT B 1 
29 30UTB 2 
28 UOUTB3 
27 IJOUT Ap 
26 I] OUT A, 
25 ^ OUT A 2 
24 3 OUT A3 
23 ]BD 
22 DCS 
21 DAo 



PIN NAMES 



DBo-7 
CLK 


I/O 


DATA BUS IBI DIRECTIONAL! 
CLOCK INPUT ~ 


BESET 




RESET INPUT 


C? 




CHIP SELECT 


BD 




READ INPUT 


WR 




WRITE INPUT 
IBUFFER ADDRESS 


IRQ 







INTERRUPT REQUEST OUTPUT 


SL0.3 


SCAN LINES 


RL0.7 i ' 
SHIFT '"* 1 


RETURN LINES 


SHIFT INPUT 


CNTL/ST8 




CONTROL/STROBE INPUT 


OUT Ao. 3 


r" 


DISPLAY IAI OUTPUTS 


OUT B -3 





DISPLAY IBI OUTPUTS 


SB • | 


8LANK DISPLAY OUTPUT 



LOGIC SYMBOL 



<^ 



IRQ RL0.7 



CLK OUT B0-3 
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FUNCTIONAL DESCRIPTION 



Since data input and display are an integral part of many 
microprocessor designs, the system designer needs an 
interface that can control these functions without placing 
a large load on the CPU. The 8279 provides this function 
for 8-bit microprocessors. 

The 8279 has two sections: keyboard and display. The 
keyboard section can interface to regular typewriter style 
keyboards or random toggle or thumb switches. The 
display section drives alphanumeric displays or a bank of 
indicator lights. Thus the CPU is relieved from scanning 
the keyboard or refreshing the display. 

The 8279 is designed to directly connect to the 
microprocessor bus. The CPU can program all operating 
modes for the 8279. These modes include: 

Input Modes 

• Scanned Keyboard — with encoded (8x8x4 key 
keyboard) or decoded (4x8x4 key keyboard) scan 
lines. A key depression generates a 6-bit encoding of 
key position. Position and shift and control status are 
stored in the FIFO. Keys are automatically debounced 
with 2-key lockout or N-key rollover. 



• Scanned Sensor Matrix — with encoded (8x8 matrix 
switches) or decoded (4x8 matrix switches) scan lines. 
Key status (open or closed) stored in RAM addressable 
by CPU. 

• Strobed Input — Data on return lines during control 
line strobe is transferred to FIFO. 

Output Modes 

• 8 or 16 character multiplexed displays that can be 
organized as dual 4-bit or single 8-bit. 

• Right entry or left entry display formats. 

Other features of the 8279 include: 

• Mode programming from the CPU. 

• Programmable clock to match the 8279 scan times to 
the CPU cycle time. 

• Interrupt output to signal CPU when there is keyboard 
or sensor data available. 

• An 8 byte FIFO to store keyboard information. 

• 16 byte internal Display RAM for display refresh. This 
RAM can also be read by the CPU. 
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HARDWARE DESCRIPTION 

The 8279 is packaged in a 40 pin DIP. The following is 
a functional description of each pin. 



No. Of 
Pins Designation 



Function 



No. Of 
Pins 



Designation Function 



8 DB0-DB7 Bi-directional data bus. All data 

and commands between the 
CPU and the 8279 are trans- 
mitted on these lines. 

1 CLK Clock from system used to gen- 

erate internal timing. 

1 RESET A high signal on this pin resets 

the 8279. 

1 CS Chip Select. A low on this pin 

enables the interface functions 
to receive or transmit. 

1 Ao Buffer Address. A high on this 

line indicates the signals in or 
out are interpreted as a com- 
mand or status. A low indicates 
that they are data. 

2 RD, WR Input/Output read and write. 

These signals enable the data 
buffers to either send data to 
the external bus or receive it 
from the external bus. 

1 IRQ Interrupt Request. In a keyboard 

mode, the interrupt line is high 
when there is data in the FIFO/ 
Sensor RAM. The interrupt line 
goes low with each FIFO/ 
Sensor RAM read and returns 
high if there is still informa- 
tion in the RAM. In a sensor 
mode, the interrupt line goes 
high whenever a change in a 
sensor is detected. 

2 V ss Vqc Ground and power supply pins. 

4 SL0-SL3 Scan Lines which are used to 

scan the key switch or sensor 
matrix and the display digits. 
These lines can be either en- 
coded (1 of 16) or decoded (1 of 
4). 

8 RL0-RL7 Return line inputs which are 

connected to the scan lines 
through the keys or sensor 
switches. They have active in- 
ternal pullups to keep them 
high until a switch closure pulls 
one low. They also serve as an 
8-bit input in the Strobed Input 
mode. 

1 SHIFT The shift input status is stored 

along with the key position on 
key closure in the Scanned 



Keyboard modes. It has an 
active internal pullup to keep it 
high until a switch closure pulls 
it low. 

1 CNTL/STB For keyboard modes this line is 

used as a control input and 
stored like status on a key clo- 
sure. The line is also the strobe 
line that enters the data into the 
FIFO in the Strobed Input mode. 
(Rising Edge). It has an active 
internal pullup to keep it high 
until a switch closure pulls it 
low. 

4 OUT Ao-OUT A3 These two ports are the outputs 
4 OUT Bo-OUT B3 for the 16 x 4 display refresh 
registers. The data from these 
outputs is synchronized to the 
scan lines (SL0-SL3) for multi- 
plexed digit displays. The two 4 
bit ports may be blanked inde- 
pendently. These two ports may 
also be considered as one 8 bit 
port. 

1 BD Blank Display. This output is 

used to blankthedisplay during 
digit switching or by a display 
blanking command. 

PRINCIPLES OF OPERATION 

The following is a description of the major elements of the 
8279 Programmable Keyboard/Display interface device. 
Refer to the block diagram in Figure 1. 

I/O Control and Data Buffers 

The I/O control section uses the CS, Ao, RD and WR lines 
to control data flow to and from the various internal 
registers andjpuffers. All data flow to and from the 8279 is 
enabled by CS. The character of the information, given or 
desired by the CPU, is identified by Ao. A logic one 
means the information is a command or status. A logic 
zero means the information is data. RD and WR determine 
the direction of data flow through the Data Buffers. The 
Data Buffers are bi-directional buffers that connect the 
internal bus_to the external bus. When the chip is not 
selected (CS = 1), the devices are in a high impedance 
state. The drivers input during WR«CS and output during 
RD«CS. 

Control and Timing Registers and Timing Control 

These registers store the keyboard and display modes and 
other operating conditions programmed by the CPU. The 
modes are programmed by presenting the proper 
command on the data lines with Ao = 1 and then sending 
a WR. The command is latched on the rising edge of WR. 
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The command is then decoded and the appropriate 
function is set. The timing control contains the basic 
timing counter chain. The first counter is a -f N prescaler 
that can be programmed to match the CPU cycle time to 
the internal timing. The prescaler is software programmed 
to a value between 2 and 31. A value which yields an 
internal frequency of 100 kHz gives a 5.1 ms keyboard 
scan time and a 10.3 ms debounce time. The other 
counters divide down the basic internal frequency to 
provide the proper key scan, row scan, keyboard matrix 
scan, and display scan times. 

Scan Counter 

The scan counter has two modes. In the encoded mode, 
the counter provides a binary count that must be 
externally decoded to provide the scan lines for the 
keyboard and display. In the decoded mode, the scan 
counter decodes the least significant 2 bits and provides a 
decoded 1 of 4 scan. Note than when the keyboard is in 
decoded scan, so is the display. This means that only the 
first 4 characters in the Display RAM are displayed. 

In the encoded mode, the scan lines are active high 
outputs. In the decoded mode, the scan lines are active 
low outputs. 

Return Buffers and Keyboard Debounce 
and Control 

The 8 return lines are buffered and latched by the Return 
Buffers. In the keyboard mode, these lines are scanned, 
looking for key closures in that row. If the debounce 
circuit detects a closed switch, it waits about 10 msec to 
check if the switch remains closed. If it does, the address 
of the switch in the matrix plus the status of SHIFT and 
CONTROL are transferred to the FIFO. In the scanned 
Sensor Matrix modes, the contents of the return lines is 
directly transferred to the corresponding row of the 
Sensor RAM (FIFO) each key scan time. In Strobed Input 
mode, the contents of the return lines are transferred to 
the FIFO on the rising edge of the CNTL/STB line pulse. 

FIFO/Sensor RAM and Status 

This block is a dual function 8x8 RAM. In Keyboard or 
Strobed Input modes, it is a FIFO. Each new entry is 
written into successive RAM positions and each is then 
read in order of entry. FIFO status keeps track of the 
number of characters in the FIFO and whether it is full or 
empty. Too many reads or writes will be recognized as an 
error. The status can be read by an RD with CS low and 
Ao high. The status logic also provides an IRQ signal 
when the FIFO is not empty. In Scanned Sensor Matrix 
mode, the memory is a Sensor RAM. Each row of the 
Sensor RAM is loaded with the status of the correspond- 
ing row of sensor in the sensor matrix. In this mode, IRQ is 
high if a change in a sensor is detected. 

Display Address Registers and Display RAM 

The Display Address Registers hold the address of the 
word currently being written or read by the CPU and the 
two 4-bit nibbles being displayed. The read/write 
addresses are programmed by CPU command. They also 
can be set to auto increment after each read or write. The 
Display RAM can be directly read by the CPU after the 
correct mode and address is set. The addresses for the A 
and B nibbles are automatically updated by the 8279 to 
match data entry by the CPU. The A and B nibbles can be 
entered independently or as one word, according to the 
mode that is set by the CPU. Data entry to the display can 
be set to either left or right entry. See Interface 
Considerations for details. 



SOFTWARE OPERATION 

8279 commands 

The following commands program the 8279 operating 
modes. The commands are sent on the Data Bus with CS 
low and Ap high and are loaded to the 8279 on the rising 
edge of WR*. 



Keyboard/Display Mode Set 

MSB 
Code: 



LSB 












D 


D 


K 


K 


K 



Where DD is the Display Mode and KKK is the Keyboard 
Mode. 

DD 

8 8-bit character display — Left entry 

1 16 8-bit character display — Left entry* 

1 8 8-bit character display — Right entry 

1 1 16 8-bit character display — Right entry 

For description of right and left entry, see Interface 
Considerations. Note that when decoded scan is set in 
keyboard mode, the display is reduced to 4 characters 
independent of display mode set. 

KKK 

Encoded Scan Keyboard — 2 Key Lockout 

1 Decoded Scan Keyboard — 2-Key Lockout 

10 Encoded Scan Keyboard — N-Key Rollover 

1 1 Decoded Scan Keyboard — N-Key Rollover 

1 Encoded Scan Sensor Matrix 
1 1 Decoded Scan Sensor Matrix 

1 1 Strobed Input, Encoded Display Scan 

1 1 1 Strobed Input, Decoded Display Scan 

Program Clock 

Code: 









1 


p 


p 


p 


P 


P 



Where PPPPP is the prescaler value 2 to 31. The 
programmable prescaler divides the external clock by 
PPPPP to get the basic internal frequency. Choosing a 
divisor that yields 100 KHz will give the specified scan and 
debounce times. Default after a reset pulse (but not a 
program clear) is 31. 

Read FIFO/Sensor RAM 



Code: 1 0AIXAAAX = Don't Care 



Where Al is the Auto-Increment flag for the Sensor RAM 
and AAA is the row that is going to be read by the CPU. Al 
and AAA are used only if the mode is set to Sensor Matrix. 
This command is used to specify that the source of data 
reads (CS • RD • Ao) by the CPU is the FIFO/Sensor 
RAM. No additional commands are necessary as long as 
'Default after reset. 
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data is desired from the FIFO/Sensor RAM. Another 
command is necessary if reading is desired from a 
different row than has been selected. If Al is a one, the row 
select counter will be incremented after each read so the 
next read will be from the next Sensor RAM row. 

In the Auto Increment mode for reading data from the 
FIFO/Sensor RAM, each read advances the address by 
one so that the next read is from the next character. This 
Auto Incrementing has no effect on the display. 

Read Display RAM 



Code: 



Where Al is the Auto-Increment flag for the Display RAM 
and AAAA is the character that the CPU is going to read 
next. Since the CPU uses the same counter for reading 
and writing, this command also sets the next write location 
and Auto-Increment mode. This command is used to 
specify the display RAM as the data source for CPU data 
reads. If Al is set, the character address will be 
incremented after each read (or write) so that the next 
read (or write) will be from (to) the next character. 






1 


1 


Al 


A 


A 


A 


A 



1 








Al 


A 


A 


A 


A 



Write Display RAM 



Code: 



Where Al is the Auto-Increment flag for the Display RAM 
and AAAA is the character that the CPU is going to write 
next. The addressing and Auto-Increment are identical to 
Read Display RAM. The difference is that Write Display 
RAM does not affect the source of CPU reads. The CPU 
will read from whichever RAM (Display or FIFO/Sensor) 
was last specified. This command will, however, change 
the location the next Display RAM read will be from if that 
source was specified. 

Display Write Inhibit/Blanking 



Code: 



1 





1 


X 


IW 


IW 


BL 


BL 



B 



B 



Where IW is Inhibit Writing (nibble A or B) and BL is 
Blanking (nibble A or B). If the display is being used as a 
dual 4-bit display, then it is necessary to mask one of the 4- 
bit halves so that entries to the Display from the CPU do 
not affect the other half. The IW flags allow the 
programmer to do this. It is also useful to be able to blank 
either half when that half is not to be displayed. The BL 
flags blank the display. The next command sets the output 
code to be used as a "blank". Default after reset is all zeros. 
Note that to blank a display formatted as a single 8-bit 
output, it is necessary to set both BL flags to entirely blank 
the display. A "1" sets the flag. Reissuing the command 
with a "0" resets the flag. 

Clear 



Code: 



Where C D is Clear Display, C F is Clear FIFO Status 
(including interrupt), and C A is Clear All. C D is used to 



1 


1 





c D 


C D 


C D 


c F 


C A 



clear all positions of the Display RAM to a programmable 
code. All ones, all zeros and hexadecimal 20 are possible. 
The 2 least significant bits of C D are also used to specify 
the blanking code (see below). 



Cq Cq Co 

X All Zeros (X = Don't Care) 

1 AB = Hex 20(0010 0000) 
1 1 All Ones 

— Enable clear display when =1 (or by Ca = 1 ) 



Clearing the display takes approximately 160 jus. During 
this time the CPU cannot write to the Display RAM. The 
MSB of the FIFO status word will be set during this time. 
C F set the FIFO status to empty and resets the interrupt 
output line. After execution of a clear command with C F 
set, the Sensor Matrix mode RAM pointer will besetto row 
0. 

Ca has the combined effect of C D and C F . C A uses the C D 
clearing code to determine how to clear the Display RAM. 
C A also resets the internal timing chain to resynchronize 
it. 

End Interrupt/Error Mode Set 



Code: 



1 1 1 E X X X X X = Don't care 



For the sensor matrix modes this command lowers the 
IRQ line and enables further writing into RAM. (The IRQ 
line would have been raised upon the detection of a 
change in a sensor value. This would have also inhibited 
further writing into the RAM until reset). 

For the N-key rollover mode — if the E bit is programmed 
to "1" the chip will operate in the special Error mode. (For 
further details, see Interface Considerations Section.) 

Status Word 

The status word contains the FIFO status, error, and 
display unavailable signals. This word is read by the CPU 
when An is high and CS and RD are low. See Interface 
Considerations for more detail on status word. 

Data Read 

Data is read when An, CS and RD are all low. The source 
of the data is specified by the Read FIFO or Read Display 
commands. The trailing edge of RD will cause the address 
of the RAM being read to be incremented if the Auto- 
Increment flag is set. FIFO reads always increment (if no 
error occurs) independent of Al. 

Data Write 

Data that is written with An, CS and WR low is always 
written to the Display RAM. The address is specified by the 
latest Read Display or Write Display command. Auto- 
Incrementing on the rising edge of WR occurs if Al set by 
the latest display command. 
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INTERFACE CONSIDERATIONS 
Scanned Keyboard Mode, 2-Key Lockout 

There are three possible combinations of conditions 
that can occur during debounce scanning. When a key is 
depressed, the debounce logic is set. Other depressed 
keys are looked for during the next two scans. If none 
are encountered, it is a single key depression and the 
key position is entered into the FIFO along with the 
status of CNTL and SHIFT lines. If the FIFO was empty, 
IRQ will be set to signal the CPU that there is an entry in 
the FIFO. If the FIFO was full, the key will not be entered 
and the error flag will be set. If another closed switch is 
encountered, no entry to the FIFO can occur. If all other 
keys are released before this one, then it will be entered 
to the FIFO. If this key is released before any other, it 
will be entirely ignored. A key is entered to the FIFO 
only once per depression, no matter how many keys 
were pressed along with it or in what order they were 
released. If two keys are depressed within the debounce 
cycle, it is a simultaneous depression. Neither key will 
be recognized until one key remains depressed alone. 
The last key will be treated as a single key depression. 



Scanned Keyboard Mode, N-Key Rollover 

With N-key Rollover each key depression is treated 
independently from all others. When a key is depressed, 
the debounce circuit waits 2 keyboard scans and then 
checks to see if the key is still down. If it is, the key is 
entered into the FIFO. Any number of keys can be 
depressed and another can be recognized and entered 
into the FIFO. If a simultaneous depression occurs, the 
keys are recognized and entered according to the order 
the keyboard scan found them. 

Scanned Keyboard — Special Error Modes 

For N-key rollover mode the user can program a special 
error mode. This is done by the "End Interrupt/Error Mode 
Set" command. The debounce cycle and key-validity 
check are as in normal N-key mode. If during a single 
debounce cycle , two keys are found depressed, this is 
considered a simultaneous multiple depression, and sets 
an error flag. This flag will prevent any further writing into 
the FIFO and will set interrupt (if not yet set). The error flag 
could be read in this mode by reading the FIFO STATUS 
word. (See "FIFO STATUS" for further details.) The error 
flag is reset by sending the normal CLEAR command with 
Cf = 1. 

Sensor Matrix Mode 

In Sensor Matrix mode, the debounce logic is inhibited. 
The status of the sensor switch is inputted directly to the 
Sensor RAM. In this way the Sensor RAM keeps an image 
of the state of the switches in the sensor matrix. Although 
debouncing is not provided, this mode has the advantage 
that the CPU knows how long the sensor was closed and 
when it was released. A keyboard mode can only indicate 
a validated closure. To make the software easier, the 
designer should functionally group the sensors by row 
since this is the format in which the CPU will read them. 
The IRQ line goes high if any sensor value change is 
detected at the end of a sensor matrix scan. The IRQ line is 
cleared by the first data read operation if the Auto- 



Increment flag is set to zero, or by the End Interrupt 
command if the Auto-Increment flag is set to one. 

Note: Multiple changes in the matrix Addressed by (SL0-3 
= 0) may cause multiple interrupts. (SLo = in the Decoded 
Mode). Reset may cause the 8279 to see multiple changes. 

Data Format 

In the Scanned Keyboard mode, the character entered 
into the FIFO corresponds to the position of the switch 
in the keyboard plus the status of the CNTL and SHIFT 
lines (non-inverted). CNTL is the MSB of the character 
and SHIFT is the next most significant bit. The next 
three bits are from the scan counter and indicate the 
row the key was found in. The last three bits are from the 
column counter and indicate to which return line the key 
was connected. 



MSB 






LSB 


CNTL 


SHIFT 


I I 
SCAN 
I.., I 


I I 

RETURN 

I I 



SCANNED KEYBOARD DATA FORMAT 

In Sensor Matrix mode, the data on the return lines is 
entered directly in the row of the Sensor RAM that 
corresponds to the row in the matrix being scanned. 
Therefore, each switch postion maps directly to a Sensor 
RAM position. The SHIFT and CNTL inputs are ignored in 
this mode. Note that switches are not necessarily the only 
thing that can be connected to the return lines in this 
mode. Any logic that can be triggered by the scan lines 
can enter data to the return line inputs. Eight multiplexed 
input ports could be tied to the return lines and scanned by 
the 8279. 



MSB 














LSB 


RL 7 


RL 6 


RL 5 


RL 4 


RL 3 


RL 2 


RLt 


RL 



In Strobed Input mode, the data is also entered to the FIFO 
from the return lines. The data is entered by the rising 
edge of a CNTL/STB line pulse. Data can come from 
another encoded keyboard or simple switch matrix. The 
return lines can also be used as a general purpose strobed 
input. 



MSB 














LSB 


RL 7 


RL 6 


RL 5 


RL 4 


RL 3 


RL 2 


RLi 


RL 



Display 

Left Entry 

Left Entry mode is the simplest display format in that each 
display position directly corresponds to a byte (or nibble) 
in the Display RAM. Address in the RAM is the left-most 
display character and address 15 (or address 7 in 8 
character display) is the right most display character. 
Entering characters from position zero causes the display 
to fill from the left. The 17th (9th) character is entered back 
in the left most position and filling again proceeds from 
there. 



7-126 



8279/8279-5 








1 


1st entry 


1 






1 


2nd entry 


1 


2 




1 


16th entry 


1 


2 




1 


17th entry 


17 


2 




1 


18th entry 


17 


18 



14 15-* — Display 
RAM 
Address 







14 15 






14 15 


15 


16 


14 15 


15 


16 


14 15 


15 


16 



LEFT ENTRY MODE 
(AUTO INCREMENT) 

Right Entry 

Right entry is the method used by most electronic 
calculators. The first entry is placed in the right most 
display character. The next entry is also placed in the right 
most character after the display is shifted left one 
character. The left most character is shifted off the end 
and is lost. 



14 15 OnDisplay 
RAM 





1 


2 


1st entry 








2 3 


2nd entry 








3 4 


3rd entry 








1 


16th entry 


1 


2 



17th entry 



18th entry 



1 2 

2 3 

2 3 







1 


15 1 




1 


2 


1 2 


1 


2 


3 


13 14 15 


14 


15 


16 


14 15 


15 


16 


17 


15 1 


16 


17 


18 



Address 



RIGHT ENTRY MODE 
(AUTO INCREMENT) 

Note that now the display position and register address do 
not correspond. Consequently, entering a character to an 
arbitrary position in the Auto Increment mode may have 
unexpected results. Entry starting at Display RAM address 
with sequential entry is recommended. 

Auto Increment 

In the Left Entry mode, Auto Incrementing causes the 
address where the CPU will next write to be incremented 
by one and the character appears in the next location. 
With non-Auto Incrementing the entry is both to the same 
RAM address and display position. Entry to an arbitrary 
address in the Auto Increment mode has no undesirable 
side effects and the result is predictable: 



1st entry 



2nd entry 



Command 
10010101 



3rd entry 



4th entry 



1 2 3 4 5 6 7-*- Display 
RAM 
Address 






1 


2 


3 


4 


5 


6 


7 


1 


2 














1 2 3 4 5 6 7 


1 


2 















Enter next at Location 5 Auto Increment 
1 2 3 4 5 6 7 



1 


2 








3 






1 2 3 4 5 6 7 


1 


2 








3 


4 





LEFT ENTRY MODE 
(AUTO INCREMENT) 



In the Right Entry mode, Auto Incrementing and non 
Incrementing have the same effect as in the Left Entry 
except if the address sequence is interrupted: 



12 3 4 5 6 7 0-*- Display 
RAM 
Address 



2 


3 


4 


5 


6 


7 





1 














1 


2 


2 3 4 5 6 7 1 














1 


2 



Enter next at Location 5 Auto Increment 



1st entry 



2nd entry 



Command 
10010101 



3rd entry 



4th entry 

RIGHT ENTRY MODE 
(AUTO INCREMENT) 

Starting at an arbitrary location operates as shown below: 
1 2 3 4 5 6 7-*- Display 



3 


4 


5 


6 


7 





1 


2 






3 






1 


2 




4 5 6 7 1 2 3 




3 


4 




1 


2 







Command 
10010101 



1st entry 

2nd entry 
8th entry 
9th entry 



RAM 
Address 



Enter next at Location 5 Auto Increment 



1 


2 


3 


4 


5 


6 


7 













1 








2 3 4 5 6 7 1 








1 


2 










4 


5 


6 


7 


8 


1 


2 


3 




5 


6 


7 


8 


9 


2 


3 


4 



RIGHT ENTRY MODE 
(AUTO INCREMENT) 
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Entry appears to be from the initial entry point. 

8/16 Character Display Formats 

If the display mode is set to an 8 character display, the on 
duty-cycle is double what it would be for a 16 character 
display (e.g., 5.1 ms scan time for 8 characters vs. 10.3 ms 
for 16 characters with 100 kHz internal frequency). 

G. FIFO Status 

FIFO status is used in the Keyboard and Strobed Input 
modes to indicate the number of characters in the FIFO 
and to indicate whether an error has occurred. There are 
two types of errors possible: overrun and underrun. 
Overrun occurs when the entry of another character into a 
full FIFO is attempted. Underrun occurs when the CPU 
tries to read an empty FIFO. 

The FIFO status word also has a bit to indicate that the 
Display RAM was unavailable because a Clear Display or 
Clear All command had not completed its clearing 
operation. 



In a Sensor Matrix mode, a bit is set in the FIFO status 
word to indicate that at least one sensor closure indication 
is contained in the Sensor RAM. 

In Special Error Mode the S/E bit is showing the error flag 
and serves as an indication to whether a simultaneous 
multiple closure error has occurred. 

FIFO STATUS WORD 
x FIFO Full 



S/E O U 



A A A ii 



| Number of 

characters in FIFO 
Error-Underrun 
Error-Overrun 

Sensor Closure/Error Flag for 
Multiple Closures 
Display unavailable 



APPLICATIONS 



8-BIT 

MICRO- DATA 
PROCESSOR BUS 
SYSTEM 



ADDRESS/ - 
BUS\ 



via tsua 

4^ 



A0 
CLK 



t. 



RETURN 
LINES 



KEYBOARD 
MATRIX 



8 COLUMNS 
8 ROWS 



7\ 



SHIFT CNTL R _ 7 
INT 



IOW 
RESET 



0-7 

'do ' 

v ss 1 



3—8 DECODER 

"S — 



£ 



SCAN LINES 



3? 



4 — 16 DECODER 



BLANK 
DISPLAY 



X 



;o 



iz 



•i DISPLAY 

CHARACTERS 
DATA 



*Do not drive the keyboard decoder with the MSB of the scan lines. 
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ABSOLUTE MAXIMUM RATINGS* 

Ambient Temperature 0°Cto 70°C 

Storage Temperature -65°Cto 125°C 

Voltage on any Pin with 

Respect to Ground -0.5V to +7V 

Power Dissipation 1 Watt 



^COMMENT: Stresses above those listed under "Absolute 
Maximum Ratings" may cause permanent damage to the 
device. This is a stress rating only and functional opera- 
tion of the device at these or any other conditions above 
those indicated in the operational sections of this specifi- 
cation is not implied. Exposure to absolute maximum 
rating conditions for extended periods may affect device 
reliability. 



D.C. CHARACTERISTICS 

Ta = 0°C to 70° C, Vss = 0V, Note 1 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


V|L1 


Input Low Voltage for 
Return Lines 


-0.5 


1.4 


V 




V|L2 


Input Low Voltage for All Others 


-0.5 


0.8 


V 




V|H1 


Input High Voltage for 
Return Lines 


2.2 




V 




V IH2 


Input High Voltage for All Others 


2.0 




V 




Vol 


Output Low Voltage 




0.45 


V 


Note 2 


Voh 


Output High Voltage on Interrupt 
Line 


3.5 




V 


Note 3 


l|L1 


Input Current on Shift, Control and 
Return Lines 




+10 
-100 


HA 
juA 


V|N = Vcc 
V| N = OV 


>IL2 


Input Leakage Current on All Others 




±10 


juA 


V| N = V C c to 0V 


>OFL 


Output Float Leakage 




±10 


MA 


Vqut = V C c to 0V 


■cc 


Power Supply Current 




120 


mA 





Notes: 

1. 8279, V cc = +5V ±5%; 8279-5, V C c = +5V ±10%. 

2. 8279, Iol= 1.6mA; 8279-5, l L= 2.2mA. 

3. 8279, Iqh = -100jliA; 8279-5, Iqh = -400/iA. 



CAPACITANCE 



SYMBOL 


TEST 


TYP. 


MAX. 


UNIT 


TEST CONDITIONS 


Gin 


Input Capacitance 


5 


10 


pF 


V in =Vcc 


C ut 


Output Capacitance 


10 


20 


pF 


Vout=V C C 
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A.C. CHARACTERISTICS 

T A = 0°C to 70° C, V ss = 0V, (Note 1 ) 
Bus Parameters 
Read Cycle: 



Symbol 


Parameter 


8279 

Min. 


Max. 


8279-5 

Min. Max. 


Unit 


*AR 


Address Stable Before READ 


50 





ns 


*RA 


Address Hold Time for READ 


5 





ns 


tRR 


READ Pulse Width 


420 


250 


ns 


tRD [2) 


Data Delay from READ 


300 


150 


ns 


tAD™ 


Address to Data Valid 


450 


250 


ns 


tDF 


READ to Data Floating 


10 


100 


10 100 


ns 


tRCY 


Read Cycle Time 


1 


1 


/is 


Write Cycle: 


Symbol 


Parameter 


8279 

Min. 


Max. 


8279-5 

Min. Max. 


Unit 






50 







*AW 


Address Stable Before WR ITE 


ns 


t\A/A 


Address Hold Time for WR ITE 


20 





ns 


t W w 


WRITE Pulse Width 


400 


250 


ns 


tDW 


Data Set Up Time for WR ITE 


300 


150 


ns 


X VJD 


Data Hold Time for WRITE 


40 





ns 



Notes: 

1. 8279, V CC = +5V ±5%; 8279-5, V cc = +5V ±10%. 

2. 8279, C L = 100pF; 8279-5, C L = 150pF. 

Other Timings: 



Symbol 


Parameter 


8279 

Min. Max. 


8279-5 
Min. Max. 


Unit 


*0W 


Clock Pulse Width 


230 


120 


nsec 


tcY 


Clock Period 


500 


320 


nsec 



Keyboard Scan Time: 5.1 msec 

Keyboard Debounce Time: 10.3 msec 

Key Scan Time: 80 Msec 

Display Scan Time: 10.3 msec 



Digit-on Time: 
Blanking Time: 
Internal Clock Cycle: 



480 Msec 
1 60 Msec 
10 Msec 



Input Waveforms For A.C. Tests 




TEST POINTS 
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WAVEFORMS 



Read Operation 

DC 



A ,CS 



\ 



DATA BUS 
(OUTPUT) 



iliS=li 



X 



/ 



■ DATA VALID- 



\ 



1 



(SYSTEM'S 
ADDRESS BUS) 



(READ CONTROL) 



HIGH IMPEDANCE^ 
WWWWWNWWN 



Write Operation 



»„.c-s -^y 



DATA BUS 
(INPUT) 



\ 



DATA 
MAY CHANGE 



X 



/ 



X 



-« DATA VALID »- 



*WD 



X 



DATA 
MAY CHANGE 



(SYSTEM'S 
ADDRESS BUS) 



(WRITE CONTROL) 



Clock Input 



1 \ / \ / 



-*CY- 
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8278 
PROGRAMMABLE KEYBOARD INTERFACE 



□ Simultaneous Keyboard and Display 
Operations 

□ Interface Signals for Contract and 
Capacitive Coupled Keyboards 

□ 128-Key Scanning Logic 

□ 10.7 msec Matrix Scan Time for 128 
Keys and 6 MHz Clock 

□ 8-Character Keyboard FIFO 



□ N-Key Rollover with Programmable 
Error Mode on Multiple New Closures 

d 16- or 18-Character 7-Segment Display 
Interface 

a Right or Left Entry Display RAM 

□ Depress/Release Mode Programmable 
a Interrupt Output on Key Entry 



The Intel® 8278 is a general purpose programmable keyboard and display interface device designed for use with 8-bit 
microprocessors such the MDS-80™ and MCS-85™. The keyboard portion can provide a scanned interface to 
128-key contact or capacitive-coupled keyboards. The keys are fully debounced with N-key rollover and 
programmable error generation on multiple new key closures. Keyboard entries are stored in an 
8-character FIFO with overrun status indication when more than 8 characters are entered. Key entries set 
an interrupt request output to the master CPU. 

The display portion of the 8278 provides a scanned display interface for LED, incandescent, and other 
popular display technologies. Both numeric displays and simple indicators may be used. The 8278 has a 
16X4 display RAM which can be loaded or interrogated by the CPU. Both right entry calculator and left en- 
try typewriter display formats are possible. Both read and write of the display RAM can be done with auto- 
increment of the display RAM address. 



PIN CONFIGURATION 



PIN NAMES 



BLOCK DIAGRAM 



X1C 2 

X2£ 3 

RESET C 4 

NCC 5 

CSC 6 

GNDE 7 

r5C 8 

A0CJ9 
WR 
SYNC 
DoC 
D,C 
D2C 
D3C 
D4C 
DsC 

DeC 

D7C 

GNDfJ 



C 10 

C n 



40 DVcc 

39 UCLR 

38 Hb 3 

37 HB 2 

36 UBi 

35 DBo 

34 DKCL 

33 DM 6 

32 UM 5 

31 ]M 4 

30 ]M 3 

29 3M 2 

28 DM, 

27 DM 

26 HV DD 

25 J NC 

24 3 ERROR 

23 DlRQ 

22 3HYS 

21 HBP 



D 7 -D 


DATA BUS 


RD, WR 


READ, WRITE STROBES 


CS 


CHIP SELECT 


Ao 


CONTROL/DATA SELECT 


RESET 


RESET INPUT 




FREQ. REFERENCE INPUT 


SYNC 


HIGH FREQUENCY OUTPUT 




CLOCK 


RL 


KEYBOARD RETURN LINE 


CLR 


CLEAR ERROR 


KCL 


KEY CLOCK 


M 6 -M 


MATRIX SCAN LINES 




DISPLAY OUTPUTS 


ERROR 


ERROR SIGNAL 


IRQ 


INTERRUPT REQUEST 


HYS 


HYSTERESIS 


BP 


TONE ENABLE 



UAl M 

/Vs bus A-N 

\-2-yZ BUFFER Xf-/' 



n 



JT 



o 



o 



r 



« 



n 



H 



SCAN /H~\ 

COUNTER \r^-V 



•KEY CLOCK 
.SYNC 
1400 KHz) 



• TONE ENABLE 

ERROR OUTPUT 
■ CLEAR INPUT 



0> 



16-DIGIT 
DISPLAY 
BUFFER 



IT /1_N 1 

Y C 4 > c 

r N— l/ t 



© Intel Corporation, 1978 



February, 1978 
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PIN DESCRIPTION 

The 8278 is packaged in a 40-pin DIP. The following is a 
brief functional description of each pin. 



Signal 



Pin No. 



Description 



D0-D7 12-19 Three-state, bi-directional data bus 

lines used to transfer data and com- 
mands between the CPU and the 
8278. 

WR 10 Write strobe which enables the mas- 

ter CPU to write data and com- 
mands between the CPU and the 
8278. 

RD 8 Read strobe which enables the mas- 

ter CPU to read data and status from 
the 8278 internal registers. 

CS 6 Chip select input used to enable 

reading and writing to the 8278. 

Ao 9 Address input used by the CPU to 

indicate control or data. 

RESET 4 A low signal on this pin resets the 

8278. 

Xi, X2 2,3 Inputs for crystal, L-C or external 

timing signal to determine internal 
oscillator frequency. 

IRQ 23 Interrupt Request Output to the 

master CPU. In the keyboard mode 
the IRQ line goes low with each 
FIFO read and returns high if there 
is still information in the FIFO or an 
ERROR has occurred. 

M0-M6 27-33 Matrix scan outputs. These out- 

puts control a decoder which scans 
the key matrix columns and the 16 
display digits. Also, the Matrix scan 
outputs are used to multiplex the 
return lines from the key matrix. 

RL 1 Input from the multiplexer which in- 

dicates whether the key currently 
being scanned is closed. 

HYS 22 Hysteresis output to the analog de- 

tector. (Capacitive keyboard config- 
uration). A "0" means the key cur- 
rently being scanned has already 
been recorded. 

KCL 34 Key clock output to the analog de- 

tector (capacitive keyboard config- 
uration) used to reset the detector 
before scanning a key. 

SYNC 11 High frequency (400 KHz) output 

signal used in the key scan to detect 
a closed key (capacitive keyboard 
configuration). 

B0-B3 35-38 These four lines contain binary 

coded decimal display information 
synchronized to the keyboard col- 
umn scan. The outputs are for 
multiplexed digital displays. 



Signal 



Pin No. 



Description 



ERROR 24 Error signal. This line is high when- 

ever two new key closures are de- 
tected during a single scan or when 
too many characters are entered 
into the keyboard FIFO. It is reset by 
a system RESET pulse or by a "1" 
input on the CLR pin or by the 
CLEAR ERROR command. 

CLR 39 Input used to clear an ERROR con- 

dition in the 8278. 

BP 21 Tone enable output. This line is high 

for 10ms following a valid key 
closure; it is set high and remains 
high during an ERROR condition. 

Vcc, Vdd 40,26 +5 volt power input: +5V ± 10%. 
GND 20,7 Signal ground. 



PRINCIPLES OF OPERATION 

The following is a description of the major elements of the 
Programmable Keyboard/Display interface device. Refer 
to the block diagram in Figure 1. 

I/O Control and Data Buffers 

The I/O control section uses the CS, Ao, RD, and WR lines 
to control data flow to and from the various internal 
registers and buffers (see Table 1). All data flow to and 
from the 8278 is enabled by CS. The 8-bits of information 
being transferred by the CPU is identified by Ao. A logic 
one means information is command or statu s. A logic zero 
means the information is data. RD and WR determine the 
direction of data flow through the Data Bus Buffer (DBB). 
The DBB register is a bi-directional 8-bit buffer register 
which connects the internal 8278 bus buffer registerto the 
external bus. When the chip is not selected (CS = 1) the 
DBB is in the hig h im pedance state. The DBB acts as an 
input when (RD, WR, CS) = (1,0, 0) and an output when 
(RD, WR, CS) = (0, 1, 0). 



CS 


Ao 


WR 


RD 


Condition 








1 





Read DBB Data 





1 


1 





Read STATUS 











1 


Write Data to DBB 





1 





1 


Write Command to DBB 


1 


X 


X 


X 


Disable 8278 Bus is 
High Impedance 


Scan Counter 









The scan counter provides the timing to scan the 
keyboard and display. The four MSB's (M3-M6) scan the 
display digits and provide column scan to the keyboard via 
a 4 to 16 decoder. The three LSB's (M0-M2) are used to 
multiplex the row return lines into the 8278. 



7-134 



8278 



» TO TONE GENERATOR 



, 8085 OR 8048 

MASTER 

PROCESSOR 




16 DIGIT SCAN 



Figure 1. System Configuration for Capacitive-Coupled Keyboard 



Keyboard Debounce and Control 

The 8278 system configuration is shown in Figure 2. The 
rows of the matrix are scanned and the outputs are 
multiplexed by the 8278. When a key closure is detected, 
the debounce logic waits about 1 2 msec to check if the key 
remains closed. If it does, the address of the key in the 
matrix is transferred into a FIFO buffer. 



FIFO and FIFO Status 

The 8278 contains an 8X8 FIFO character buffer. Each 
new entry is written into a successive FIFO location and 
each is then read out in the order of entry. A FIFO status 
register keeps track of the number of characters in the 



FIFO and whether it is full or empty. Too many reads or 
key entries will be recognized as an error. The status can 
be read by a RD with CS low and Ao high. The status logic 
also provides a IRQ signal to the master processor 
whenever the FIFO is not empty. 

Display Address Registers and Display RAM 

The Display Address registers hold the address of the 
word currently being written or read by the CPU and the 
two 4-bit nibbles being displayed. The read/write 
addresses are programmed by CPU command. They also 
can be set to auto increment after each read or write. The 
display RAM can be directly read by the CPU after the 
correct mode and address is set. Data entry to the display 
can be set to either left or right entry. 



, 8085 OR 8048 

MASTER" 

PROCESSOR 



c 



-»- TO TONE GENERATOR 



ERROR 
CLR 



v D °- 



8278 



A. 



16 DIGIT SCAN 



CONTACT 

KEYBOARD 

MATRIX 



8 OR 16 DIGIT DISPLAY 



Figure 2. System Configuration for Contact Keyboard 
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8278 COMMANDS 

The 8278 operating mode is programmed by the master 
CPU using the Ao, WR, and D0-D7 inputs as shown below: 



A ,CS INVAL 



X 



X 



Where Al indicates Auto Increment and A3-A0 is the 
address of the next display character to be read out. 

Al=1 AUTO increment 
Al=0 no AUTO increment 

Write Display Command 



CODE 1 Al A3 A 2 A, Aq 



D0-D7 



\_y 



" X v,u ° ) C 



The master CPU presents the proper command on the Do- 
D7 data lines with Ao=1 and then sends a WR pulse. The 
command is latched by the 8278 on the rising edge of the 
WR and is decoded internally to set the proper operating 
mode. 

COMMAND SUMMARY 
Keyboard/Display Mode Set 












N 


E 


I 


D 


K 



Where Al indicates Auto Increment and A3-A0 is the 
address of the next display character to be written. 

Clear/Blank Command 



1 





1 


uo 


BD 


CD 


CF 


CE 



Where the command bits are defined as follows: 

CE = Clear ERROR 

CF = Clear FIFO 

CD = Clear Display to all High 

BD = Blank Display to all High 

UD = Unblank Display 

The display is cleared and blanked following a Reset. 
8278 Status Read 

The status register in the 8278 can be read by the master 
CPU using the Ao, RD, and D0-D7 inputs as shown below: 



where the mode set bits are defined as follows: 

K — the keyboard mode select bit 

— normal key entry mode 

1 — special function mode: Entry on key closure and on 

key release 

D — the display entry mode select bit 

— left display entry 

1 — right display entry 

I — the interrupt request (IRQ) output enable bit. 

— enable IRQ output 

1 — disable IRQ output 

E — the error mode select bit 

— error on multiple key depression 

1 — no error on multiple key depression 



N — the number of display digits select 
0— 16 display digits 
1—8 display digits 

NOTE: The default mode following a RESET input 
is all bits zero: 





























Read F 


IFO Command 


CODE 





1 




















Read C 


lisplay Command 


CODE 





1 


1 


Al 


A3 


A 2 


Ai 


Ao 



Aq, cS 



X 



X 



\ 



/ 



The 8278 places 8-bits of status information on the D0-D7 
lines following (Ao, CS, RD) = 1,0,0 inputs from the 
master. 



Status Format 



S3 


s 2 


Si 


So 


B 


KE 


OBF 


IBF 



D7 D 6 D 5 D 4 



Do 



Where the status bits are defined as follows: 

IBF = Input Buffer Full Flag 

OBF = Output Buffer Full Flag 

KE = Keyboard Error Flag (multiple depression) 

B = BUSY Flag 

S3-S0 = FIFO Status 
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Status Description 

The S3-S0 status bits indicate the number of entries (0 to 8) 
in the 8-level FIFO. A FIFO overrun will lock status at 1 1 1 1 . 
The overrun condition will prevent further key entries until 
cleared. 

A multiple key closure error will set the KE flag and 
prevent further key entries until cleared. 

The IBF and OBF flags signify the status of the 8278 data 
buffer registers used to transfer information (data, status 
or commands) to and from the master CPU. 

The IBF flag is set when the master CPU writes Data or 
Commands to the 8278. The IBF flag is cleared by the 8278 
during its response to the Data or Command. 

The OBF flag is set when the 8278 has output data ready 
for the master CPU. This flag is cleared by a master CPU 
Data READ. 

The Busy flag in the status register is used as a LOCK- 
OUT signal to the master processor during response to 
any command or data write from the master. 

The master must test the Busy flag before each read 
(during a sequence) to be sure that the 8278 is ready with 
valid DATA. 

The ERROR and TONE outputs from the 8278 are set high 
for either type of error. Both types of error are cleared by 
the CLR input, by the CLEAR ERROR command, or by a 
reset. The FIFO and Display buffers are cleared 
independently of the Errors. 

FIFO status is used to indicate the number of charactersin 
the FIFO and to indicate whether an error has occurred. 
Overrun occurs when the entry of another character into a 
full FIFO is attempted. Underrun occurs when the CPU 
tries to read an empty FIFO. The character read will be the 
last one entered. FIFO status will remain at 0000 and the 
error condition will not be set. 

8278 Data Read 

The master CPU can read DATA from the 8278 FIFO or 
Display buffers by using the Ao, RD, and D0-D7 inputs as 
follows: 



Ao.es 



X 



X 



\ 



/ 



The master sends a RD pulse with Ao=0 and CS=0 and the 
8278 responds by outputing data on lines D0-D7. The data 
is strobed by the trailing edge of RD. 



Data Read Sequence 

Before reading data, the master CPU must send a 
command to select FIFO or Display data. Following the 
command, the master must read STATUS and test the 
BUSY flag and the OBF flag to verify that the 8278 has 
responded to the previous command. A typical DATA 
READ sequence is as follows: 



J 



L 



READ DISPLAY 
OR FIFO COMMAND 
FROM MASTER 


FIRST 

DATA BYTE 
READY 


MASTER 
READS DATA 


NEXT 

BYTE READY 
8278 

PROCESSING 
NEXT BYTE 



After the first read following a Read Display or Read FIFO 
command, successive reads may occur as soon as OBF 
rises. 

8278 Data Write 

The master CPU can write DATA to the 8278 Display 
buffers by using the Ao, WR and D0-D7 inputs as follows: 



A ,CS INVALID Y 


VALID 


X 


INVALID 






WR \ 


/ 




D -D 7 //////////INVALID ///// 


m- 


■"■ M 


f/ff| 
////INVALID'//, 

//////////////////. 



The master CPU presents the Data on the D0-D7 lines with 
Ao=0 and then sends a WR pul se. The data is latched by 
the 8278 on the rising edge of WR. 

Data Write Sequence 

Before writing data to the 8278, the master CPU must first 
send a command to select the desired display entry mode 
and to specify the address of the next data byte. Following 
the commands, the master must read STATUS and test the 
BUSY flag (B) and IBF flag to verify that the 8278 has 
responded. A typical sequence is shown below: 



T 



WRITE DISPLAY 


8278 MASTER 


8278 




8278 


COMMAND 


READY DATA WRITE 


READY 




READY 




FOR FIRST BYTE 

COMMAND 

OR DATA 


MASTE 
NEXTB 


1 WRITES 
YTE 
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INTERFACE CONSIDERATIONS 

Scanned Keyboard Mode 

With N-key rollover each key depression is treated 
independently from all others. When a key is depressed 
the debounce logic waits for a full scan of 128 keys and 
then checks to see if the key is still down. If it is, the key is 
entered into the FIFO. 



1 R 



J\ A A A. 



• y r 



n n n n. 



Figure 3. Keyboard Timing 



If two key closures occur during the same scan the 
ERROR output is set, the KE flag is set in the Status word, 
the TONE output is activated and IRQ is set, and no further 
inputs are accepted. This condition is cl eared b y a high 
signal on the CLEAR input or by a system RESET input or 
by the CLEAR ERROR command. 



In the special function mode both the key closure and the 
key release cause an entry to the FIFO. The release is 
entered with the MSB=1. 

Any key entry triggers the TONE output for 10ms. 

The HYS and KCL outputs enable the analog multiplexer 
and detector to be synchronized for interface to capacitive 
coupled keyboards. 



SCAN CYCLE I 



t I 



KEY1 
DEPRESSED 



KEY1 
ENTERED 



KEY1 

READ BY MASTER 



KEY 2 KEY 3 

DEPRESSED DEPRESSED 



Figure 4. Key Entry and Error Timing 
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Data Format 

In the scanned keyboard mode, the code entered into the 
FIFO corresponds to the position or address of the switch 
in the keyboard. The MSB is relevant only for special 
function keys in which code "0" signifies closure and "1" 
signifies release. The next four bits are the column count 
which indicates which column the key was found in. The 
last three bits are from the row counter. 

KEY CODING 



SF 


M 6 


M 5 


M 4 


M 3 


M 2 


M, 


M 



1 FOR SPECIAL FUNCTION 
-MODE AND KEY RELEASED 
FOR KEY DEPRESSED 



Display 

Display data is entered into a 16x4 display register and 
may be entered from the left, from the right or into specific 
locations in the display register. A new data character is 
put out on B0-B3 each time the M6-M3 lines change (i.e., 
once every 0.75ms with a 6 MHz crystal). Data is blanked 
during the time the column select lines change by raising 
the display outputs. Output data is positive true. 

Left Entry 

The left entry mode is the simplest display format in that 
each display position in the display corresponds to a byte 
(or nibble) in the Display RAM. Address in the RAM is the 
left-most display character and address 15 is the right- 
most display character. Entering characters from position 
zero causes the display to fill from the left. The 17th 
character is entered back in the left-most position and 
filling again proceeds from there. 



Right Entry 

Right entry is the method used by most electronic 
calculators. The first entry is placed in the right-most 
display character. The next entry is also placed in the 
right-most character after the display is shifted left one 
character. The left-most character is shifted off the end 
and is lost. 



DISPLAY 
■RAM 
ADDRESS 





1 


2 




14 


15 


0* 


1ST ENTRY 












1 




2 


3 15 





1 


2ND ENTRY 










1 


2 




3 


4 


1 


2 


3RD ENTRY 








1 


2 


3 







1 13 


14 


15 


16TH ENTRY 


1 


2 




14 


15 


16 




1 


2 14 


15 





17TH ENTRY 


2 


3 




15 


16 


17 




2 


3 15 





1 


18TH ENTRY 


3 


4 




16 


17 


18 



Note that now the display position and register address do 
not correspond. Consequently, entering a character to an 
arbitrary position in the Auto Increment mode may have 
unexpected results. Entry starting at Display RAM address 
with sequential entry is recommended. A Clear Display 
command should be given before display data is entered if 
the number of data characters is not equal to 16 (or 8) in 
this mode. 



~\ / \ I \ / \ / \ / \ / V 



Figure 5. Display Timing 
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Auto Increment 

In the Left Entry mode, Auto Incrementing causes the 
address where the CPU will next write to be incremented 
by one and the character appears in the next location. 
With non-Auto Incrementing the entry is both to the same 
RAM address and display position. Entry to an arbitrary 
address in the Left Entry — Auto Increment mode has no 
undesirable side effects and the result is predictable: 



DISPLAY 
12 3 4 5 6 7~t— RAM 

ADDRESS 



1ST ENTRY 


1 





















1 


2 


3 


4 


5 


6 


7 


2ND ENTRY 


1 


2 



















1 


2 


3 


4 


5 


6 


7 


COMMAND 
10010101 


1 


2 















ENTER NEXT AT LOCATION 5 AUTO INCREMENT 
12 3 4 5 6 7 



3RD ENTRY 


1 


2 








3 











1 


2 


3 


4 


5 


6 


7 


4TH ENTRY 


1 


2 








3 


4 





In the Right Entry mode, Auto Incrementing and non 
Incrementing have the same effect as in the Left Entry 
except that the address sequence is interrupted: 



DISPLAY 

1 2 3 4 5 6 7 -« — RAM 

ADDRESS 



1ST ENTRY 
















1 




2 


3 


4 


5 


6 


7 





1 


2ND ENTRY 












1 


2 




2 


3 


4 


5 


6 


7 





1 


COMMAND 
10010101 


| 










1 


2 



ENTER NEXT AT LOCATION 5 AUTO INCREMENT 
3 4 5 6 7 12 



3RD ENTRY 






3 






1 


2 






4 


5 


6 


7 





1 


2 


3 


4TH ENTRY 




3 


4 




1 


2 







Starting at an arbitrary location operates as shown below: 



COMMAND 
10010101 



DISPLAY 
12 3 4 5 6 7- — RAM 

ADDRESS 



ENTER NEXT AT LOCATION 5 AUTO INCREMENT 
1 2 3 4 5 6 7 



1ST ENTRY 










1 










2 3 4 5 6 7 1 


2ND ENTRY 








1 


2 












8TH ENTRY 


4 


5 


6 


7 


8 


1 


2 


3 






9TH ENTRY 


5 


6 


7 


8 


9 


2 


3 


4 



Entry appears to be from the initial entry point. 
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ABSOLUTE MAXIMUM RATINGS* 

Ambient Temperature UnderBias 0°Cto70°C 

Storage Temperature -65°Cto+150°C 

Voltage on Any Pin With 

Respect to Ground 0.5Vto+7V 

Power Dissipation 1.5 Watt 



'COMMENT: Stresses above those listed under "Absolute 
Maximum Ratings" may cause permanent damage to the 
device. This is a stress rating only and functional 
operation of the device at these or any other conditions 
above those indicated in the operational sections pfAhis^ 
specification is not implied. Exposure to absolute, 
maximum rating conditions for extended periods may 
affect device reliability. 



D.C. CHARACTERISTICS 

Commercial: T A = 0°C to 70° C; Vcc = +5V ±5%; Vss = 0V 



Symbol 


Parameter 


Min. 


Max. 


Units 


Condition 


VlL 


Input Low Voltage (All Inputs 
Except Xi, X2 


-0.5 


0.8 


V 




Vim 


Input High Voltage (All Inputs 
Except Xi, X2, RESET 


2.0 


Vcc 


V 




V|H2 


RESET High Voltage 


3.0 


Vcc 


V 




VOL1 


Output Low Voltage (D0-D7) 




0.45 


V 


Iol = 2.0mA 


VOL2 


Output Low Voltage (All 
Other Outputs) 




0.45 


V 


Iol = 1.6mA 


VOH1 


Output High Voltage (D0-D7) 


2.4 




V 


lOH = -400/iA 


VOH2 


Output High Voltage (All 
Other Outputs) 


2.4 




V 


lOH = -50^A 


IlL 


Input Leakage Current (All 
Inputs Except RESET) 




±10 


ma 


Vin = Vcc 


lOL 


Output Leakage Current (D0-D7) 




±10 


;uA 


Vin = Vss + 0.45V or 
Vin = Vcc 


Idd + Ice 


Total Supply Current 




135 


mA 


Vcc = 5.5V 


Idd 


Vdd Supply Current 




25 


mA 


Vcc = 5.5V 


Ili 


Low Input Source Current (RESET) 




0.2 


mA 


Vil = 0.8V 



8278 CLOCK OPTIONS 









Q 


Xi 
*2 


8278 


1/2 

7474 


5 






D 





1-6 MHz 
CRYSTAL 



40juh-130Mh 
INDUCTOR 



EXTERNAL 
CLOCK 



7-141 



8278 



A.C. CHARACTERISTICS 

Ta = 0°C to 70° C; Vcc = +5V ±10%; Vss = 0V 



Symbol 


Parameter 


Min. 


Max. 


Units 


Condition 


tAC 


Address (CS, Ao) Setup to 
Control (RD, WR) 







ns 




tCA 


Address Hold from Control 







ns 




tec 


Control Pulse Width 


250 




ns 


D0-D7, Cl - 150pF 


tDW 


Data in Setup to WR T.E. 


150 




ns 


tWD 


Data in Hold After WR T.E. 







ns 




tRD 


RD L.E. to Data Out Valid 




150 


ns 




tDF 


RD T.E. to Data Out Float 


10 


100 


ns 




tMCY 


Matrix Cycle Time 




10.7 


ms 


With 6MHz Crystal 


tRV 


Recovery Time Between Reads 
and/or Writes 


1 




fiS 





WAVEFORMS 

Read Operation — Data Bus Buffer Register 

CS OR A Y 



X 



\ 



< 



-<DF — *j 



- DATA VALID- 



> 



Write Operation — Data Bus Buffer Register 

C§ OR A j(\ 



X 



\ 



I 



V 



(READ CONTROL) 



(WRITE CONTROL) 



Xz 



-DATA VALID- 



X 
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8041/8741 

UNIVERSAL PERIPHERAL INTERFACE 

8-BIT MICROCOMPUTER 



□ Fully Compatibnle with MCS-80™, 
MCS-85™ and MCS-48™ Microproces- 
sor Families 

□ Single Level Interrupt 

a 8-Bit CPU plus ROM, RAM, I/O, Timer 
and Clock in a Single Package 

d Single 5V Supply 

□ Alternative to Custom LSI 



d Pin Compatible ROM and EPROM 
Versions 

a 1K x 8 ROM/EPROM, 64 x 8 RAM, 18 
Programmable I/O Pins 

□ Asynchronous Data Register for 
Interface to Master Processor 

d Expandable I/O 



The Intel® 8041/8741 is a general purpose, programmable interface device designed for use with a variety of 8-bit 
microprocessor systems. It contains a low cost microcomputer with program memory, data memory, 8-bit CPU, I/O ports, 
timer/counter, and clock in a single 40-pin package. Interface registers are included to enable the U PI device to function as 
a peripheral controller in MCS-80™, MCS-85™, MCS-48™, and other 8-bit systems. 

The UPI-41™ has 1K words of program memory and 64 words of data memory on-chip. To allow full user flexibility the 
program memory is available as ROM in the 8041 version or as UV-erasable EPROM in the 8741 version. The 8741 and the 
8041 are fully pin compatible for easy transition from prototype to production level designs. 

The device has two 8-bit, TTL compatible I/O ports and two test inputs. Individual port lines can function as either inputs or 
outputs under software control. I/O can be expanded with the 8243 device which is directly compatible and has 16 I/O lines. 
An 8-bit programmable timer/counter is included in the UPI device for generating timing sequences or counting external 
inputs. Additional UPI features include: single 5V supply, low power standby mode (in the 8041 ), single-step mode for 
debug(in the 8741), single level interrupt, and dual working register banks. 

Because it's a complete microcomputer, the UPI provides more flexibility for the designer than conventional LSI interface 
devices. It is designed to be an efficient controller as well as an arithmetic processor. Applications include keyboard 
scanning, printer control, display multiplexing and similar functions which involve interfacing peripheral devices to 
microprocessor systems. 



PIN CONFIGURATION 



BLOCK DIAGRAM 






MEMORY 


REG BANK 1 


STACK 


REG. BANK 




| MULTIPLEXER | 



c=>,° 



PROM 
MEMORY 



=2f 

SAM f 



c=x* 



ONDITIONAL 
BRANCH 
LOGIC 



© Intel Corporation, 1978 



February, 1978 
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ABSOLUTE MAXIMUM RATINGS* 

Ambient Temperature Under Bias 0°Cto70°C 

StorageTemperature -65°Cto+150°C 

Voltage on Any Pin With 

RespecttoGround -0.5Vto+7V 

Power Dissipation 1.5 Watt 

D.C. AND OPERATING CHARACTERISTICS 



'COMMENT: Stresses above those listed 'under "Absolute 
Maximum Ratings" may cause permanent damage to the 
device. This is a stress rating only and functional opera-., 
tion of the device at these or any other conditions above 
those indicated in the operational sections of this specifi- 
cation is not implied. Exposure to absolute maximum 
rating conditions for extended periods may affect device 
reliability. 



T A = 0°Cto 70°C, V cc = V DD = +5V ±5%, 


V ss = 0V 










Parameter 


Limits 


Unit 




Symbol 


Min. 


Typ. 


Max. 


Test Conditions 


VlL 


Input Low Voltage(AII 
Except Xi, X2) 


-0.5 




0.8 


V 




VlH 


Input High Voltage (All 
Except Xi, X 2 RESET) 


2.0 




Vcc 


V 




V|H2 


Input High Voltage (Xi, 
RESET) 


3.0 




Vcc 


V 




Vol 


Output Low Voltage (D0-D7, 
Sync) 






0.45 


V 


Iol = 2.0 mA 


VOL2 


Output Low Voltage (All 
Other Outputs Except Prog) 






0.45 


V 


Iol = 1.6 mA 


VOH 


Output High Voltage (D0-D7) 


2.4 






V 


Ioh = -400/uA 


V0H1 


Output High Voltage (All 
Other Outputs) 


2.4 






V 


'oh = -50/M 


IlL 


Input Leakage Current 

(To, Ti, RD, WR, CS, Ao, EA) 






±10 


mA 


Vss < Vin < VCC 


lOL 


Output Leakage Current 
(D0-D7, High Z State) 






+10 


VlA 


Vss + 0.45 < Vin < Vcc 


Idd 


Vdd Supply Current 




10 


25 


mA 




•cc + 'dd 


Total Supply Current 




65 


135 


mA 




VoL3 


Output Low Voltage (Prog) 






0.45 


V 


Iol = 1.0 mA 


lun 


Low Input Source Current 
P10-P17 P20-P27 






0.4 


mA 


Vil = 0.8V 


•l!2 


Low Input Source Current 
RESET, SS 






0.2 


mA 


Vil = 0.8V 



A.C. CHARACTERISTICS 

T A = 0°C to 70°C, V cc = V DD = + 5V ± 5%, V ss = 0V 
DBB Read: 



Symbol 


Parameter 


8741 


8041 


Units 


Test Conditions 


Min. 


Max. 


Min. 


Max. 


*AR 


CS, A Setup to RD i 


60 









ns 




*RA 


CS, A Hold After RD t 


30 









ns 




l RR 


RD Pulse Width 


300 


2xt CY 


250 . 




ns 


t CY = 2.5 pS 


*AD 


CS, A to Data Out Delay 




370 




150 


ns 




l RD 


RD I to Data Out Delay 




200 




150 


ns 




tDF 


RD t to Data Float Delay 


10 




10 




ns 






140 




100 


ns 




*RV 


Recovery Time Between Reads 
And/Or Write 


1 




1 




MS 




tcY 


Cycle Time 


2.5 




2.5 




MS 


6 MHz Crystal 



8041/8741 



DBB Write: 



Symbol 


Parameter 


8741 


8041 


Units 


Test Conditions^ 


Min. 


Max. 


Min. 


Max. 


Uw 


CS, A Setup to WR 1 


60 









ns 




t\NA 


CS, A Hold After WR t 


30 









ns 




tww 


WR Pulse Width 


300 


2xt CY 


250 




ns 


t CY = 2.5 MS 


*DW 


Data Setup to WR t 


250 




150 




ns 




tWD 


Data Hold After WR t 


30 









ns 





A.C. TEST CONDITIONS 

D 7 -D Outputs R L = 2.2kto Vss 
4.3k to V C c 
C L = 100 pF 



WAVEFORMS 

Read Operation — Data Bus Buffer Register 



CSOR A„ 



y. 



\ 



< 



x 



/ 



DATA VALID- 



:> 



(READ CONTROL) 



Write Operation — Data Bus Buffer Register 



a°ZIX_ 



X 



\ 



I 



(WRITE CONTROL) 



X 



X 
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PIN DESCRIPTION 
Signal Description 



UPI INSTRUCTION SET 



D0-D7 



P10-P17 


8-bit 




lines 


P20-P27 


8-bit 




lines 



WR 



RD 



CS 



Ao 



To, T1 



Xt, X 2 



SYNC 



EA 
PROG 



RESET 



SS 



Vcc 
Vdd 



Vss 



Three-state, bi-directional, DATA BUS 
BUFFER lines used to interface the UPI-41 
to an 8-bit master system data bus. 

PORT 1, quasi-bi-directional I/O 



PORT 2, quasi-bi-directional I/O 



The lower 4-bits (P20-P23J interface directly 
to the 8243 I/O expander device and con- 
tain address and data information during 
PORT 4-7 access. 

I/O write input which enables the master 
CPU to write data and command words to 
the UPI-41 DATA BUS BUFFER. 

I/O read input which enables the master 
CPU to read data and status words from the 
DATA BUS BUFFER or status register. 

Chip select input used to select one UPI-41 
out of several connected to a common data 
bus. 

Address input used by the master proces- 
sor to indicate whether byte transfer is data 
or command. 

Input pins which can be directly tested 
using conditional branch instructions. 

T-| also functions as the event timer input 
('under software control,). 

To is used during PROM programming and 
verification in the 8741. 

Inputs for a crystal, LC or an external tim- 
ing signal to determine the internal oscil- 
lator frequency. 

Output signal which occurs once per UPI- 
41 instruction cycle. SYNC can be used as a 
strobe for external circuitry; it is also used 
to synchronize single step operation. 

External access input which allows emula- 
tion, testing and PROM/ROM verification. 

Multifunction pin used as the program 
pulse input during PROM programming. 

During I/O expander access the PROG pin 
acts as an address/data strobe to the 8243. 

Input used to reset status flip-flops and to 
set the program counter to zero. 



RESET is also used during PROM program- 
ming and verification. 

Single step input used in the 8741 in 
conjunction with the SYNC output to step 
the program through each instruction. 

+5V power supply pin. 

+5V during normal operation. Programming 
supply pin during PROM programming. Low 
power standby pin in ROM version. 
Circuit ground potential. 



Mnemonic 


Description Bytes 


> Cycles 


ACCUMULATOF 


I 




ADDA.Rr 


Add register to A 




ADD A,@Rr 


Add data memory to A 




ADD A,#data 


Add immediate to A 




ADDC A,Rr 


Add immed. to A with carry 




ADDC A,@Rr 


Add immed. to A with carry 




ADDC A,#data 


Add immed. to A with carry < 


I 2 


ANLA.Rr 


AND register to A 




ANL A,@Rr 


AND data memory to A 




ANL A,#data 


AND immediate to A 




ORL A,Rr 


OR register to A 




0RLA,@Rr 


OR data memory to A 




ORL A,#data 


OR immediate to A 




XRL A,Rr 


Exclusive OR register to A 




XRLA,@Rr 


Exclusive OR data memory to A 




XRL A.tfdata 


Exclusive OR immediate to A 




INC A 


Increment A 




DEC A 


Decrement A 




CLRA 


Clear A 




CPLA 


Complement A 




DA A 


Decimal Adjust A 




SWAP A 


Swap digits of A 




RLA 


Rotate A left 




RLCA 


Rotate A left through carry 




RRA 


Rotate A right 




RRCA 


Rotate A right through carry 




INPUT/OUTPUT 




IN A,Pp 


Input port to A 


1 2 


OUTL Pp.A 


Output A to port 


1 2 


ANL Pp,#data 


AND immediate to port 


2 2 


ORL Pp,#data 


OR immediate to port 


2 2 


IN A.DBB 


Input DBBto A, clear IBF 


1 1 


OUTDBB.A 


Output A to DBB, set OBF 


1 1 


MOVD A,Pp 


Input Expander port to A 


1 2 


MOVD Pp,A 


Output A to Expander port 


1 2 


ANLD Pp,A 


AND A to Expander port 


1 2 


ORLD Pp,A 


OR A to Expander port 


1 2 


DATA MOVES 






MOVA.Rr 


Move register to A 


1 1 


MOV A,@Rr 


Move data memory to A 


1 1 


MOV A,#data 


Move immediate to A 


2 2 


MOV Rr,A 


Move A to register 


1 1 


MOV @Rr,A 


Move A to data memory 


1 1 


MOV Rr,#data 


Move immediate to register 


2 2 


MOV @Rr,#datc 


Move immediate to data memory 


2 2 


MOV A, PSW 


Move PSW to A 


1 1 


MOV PSW.A 


Move A to PSW 


1 1 


XCH A,Rr 


Exchange A and register 


1 1 


XCH A,@Rr 


Exchange A and data memory 


1 1 


XCHDA,@Rr 


Exchange digit of A and register 


1 1 


MOVP A,@A 


Move to A from current page 


1 2 


M0VP3, A,@A 


Move to A from page 3 


1 2 


TIMER/COUNTER 




MOV A,T 


Read Timer/Counter 1 




MOV T,A 


Load Timer/Counter 1 




STRTT 


Start Timer 1 




STRT CNT 


Start Counter 1 




STOP TCNT 


Stop Timer/Counter 1 




EN TCNTI 


Enable Timer/Counter Interrupt 1 




DIS TCNTI 


Disable Timer/Counter Interrupt 1 
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Mnemonic 


Description 


Bytes Cycles 










CONTROL 


CLRF1 


Clear F1 Flag 


1 


1 


EN I 


Enable IBF Interrupt 


1 1 


CPLF1 


Complement F1 Flag 


1 


1 


DISI 


Disable IBF Interrupt 


1 1 










SEL RBO 


Select register bank 


1 1 


BRANCH 








SEL RB1 
NOP 


Select register bank 1 
No Operation 


1 1 
1 1 


JMPaddr 
JMPP@A 


Jump unconditional 
Jump indirect 


2 
1 


2 
2 


REGISTERS 






DJNZ R.addr 


Decrement register and skip 


2 


2 


INC Rr 


Increment register 


1 1 


JC addr 


Jump on Carry = 1 


2 


2 


INC @Rr 


Increment data memory 


1 1 


JNC addr 


Jump on Carry = 


2 


2 


DECRr 


Decrement register 


1 1 


JZ addr 


Jump on A Zero 


2 


2 








JNZ addr 


Jump on A not Zero 


2 


2 


SUBROUTINE 






JTO addr 


Jump on TO = 1 


2 


2 


CALL addr 


Jump to subroutine 


2 2 


JNTO addr 


Jump on TO = 


2 


2 


RET 


Return 


1 2 


JT1 addr 


Jump on T1 = 1 


2 


2 


RETR 


Return and restore status 


1 2 


JNT1 addr 


Jump on T1 = 


2 


2 


FLAGS 






JFO addr 


Jump on FO Flag = 1 


2 


2 






JF1 addr 


Jump on F1 Flag = 1 


2 


2 


CLRC 


Clear Carry 


1 1 


JTF addr 


Jump on Timer Flag = 1, Clear 


Flag 2 


2 


CPLC 


Complement Carry 


1 1 


JNIBF addr 


Jump on IBF Flag = 


2 


2 


CLRFO 


Clear Flag 


1 1 


JOBF addr 


Jump on OBF Flag = 1 


2 


2 


CPLFO 


Complement Flag 


1 1 


JBbaddr 


Jump on Accumulator Bit 


2 


2 



APPLICATIONS 




PERIPHERAL 

CONTROL 

INTERFACE 



THE 8041 DOES NOT REQUIRE 
8216 BUS DRIVERS 



Figure 1. Recommended 8741 Interface to an 8085 System 



\7 



7\ 



PORT 2 PROG 





DOT MATRIX PRINTER 

FORM 
PRINT L.F. HOLD SOLENOIDS 








. 


, 


Z 

o 


2 
o 

o 

a. 
o 

H 


Z 

o 

o 
a 

z 




ft 






MOTOR 
DRIVERS 


o 

a. 




SOLENOID 
DRIVERS 














z 




7 OR 9 






PORT 2 PORT 2 PORT 1/PORT 2 
8041/8741 
DBB CONTROL 





\ DATA BUS 



\ CONTROL BUS~ 



CONTROL BUS 



Figure 2. 8041-8243 Keyboard Scanner 



Figure 3. 8041 Matrix Printer Interface 
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PROGRAMMING, VERIFYING, AND 
ERASING THE 8741 EPROM 



Programming/Verification 



In brief, the programming process consists of: activat- 
ing the program mode, applying an address, latching the 
address, applying data, and applying a programming 
pulse. Each word is programmed completely before 
moving on to the next and is followed by a verification 
step. The following is a list of the pins used for program- 
ming and a description of their functions: 



Pin 


Function 


XTAL1 


Clock input (1 to 6 MHz) 


RESET 


Initialization and address latching 


TESTO 


Selection of program or verify mode 


EA 


Activation of program/verify modes 


BUS 


Address and data input data output during 




verify 


P20-1 


Address input 


Vdd 


Programming power supply 


PROG 


Program pulse input 



The program/verify sequence is: 

1. Vdd = 5V, clock applied or internal oscillator 
operating, RESET = 0V, TEST = 5V, EA = 5V, 
BUS and PROG floating. 

2. Insert 8741 in programming socket. 

3. TEST = 0V (select program mode). 

4. EA = 25V (activate program mode). 

5. Address applied to BUS and P20-1. 

6. RESET = 5V (latch address). 

7. Data applied to BUS. 

8. V D = 25V (programming power). 

9. PROG = 0V followed by one 50 ms pulse to 25V. 

10. V DD = 5V. 

11. TESTO = 5V (verify mode). 

12. Read and verify data on BUS. 

13. TESTO = 0V. 

14. RESET = 0V and repeat from step 5. 

15. Programmer should be at conditions of step 1 when 
8741 is removed from socket. 

Programming Options 

The 8741 EPROM can be programmed by either of two 
Intel products: 

1. PROMPT-48 Microcomputer Design Aid. 

2. Universal PROM Programmer (UPP-101 or UPP-102) 
Peripheral of the Intellec® Development System with 
a UPP-848 Personality Card. 



+5V - 



+25V 

+5V ■ 



BUS AND PROG CAN BE DRIVEN ONLY DURING THIS TIME 



< 



ADDRESSA -A 7 



X 



) — < 



ADDRESS A 8 



A 9 / - 



vdd 



WARNING: An attempt to program a missocketed 8748 will result in severe damage to the part. An indication of a properly socketed part 
is the appearance of the ALE clock output. The lack of this clock may be used to disable the programmer. 



Figure 5. Programming/Verification Sequence 
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8741 Erasure Characteristics 



The erasure characteristics of the 8741 are such that 
erasure begins to occur when exposed to light with 
wavelengths shorter than approximately 4000 Ang- 
stroms (A). It should be noted that sunlight and certain 
types of fluorescent lamps have wavelengths in the 
3000-4000A range. Data show that constant exposure to 
room level fluorescent lighting could erase the typical 
8748 in approximately 3 years while it would take ap- 
proximately one week to cause erasure when exposed 
to direct sunlight. If the 8741 is to be exposed to these 
types of lighting conditions for extended periods of 



time, opaque labels are available from Intel which 
should be placed over the 8741 window to prevent 
unintentional erasure. 

The recommended erasure procedure for the 8741 is ex- 
posure to shortwave ultraviolet light which has a wave- 
length of 2537 A. The integrated dose (i.e., UV intensity 
x exposure time) for erasure should be a minimum of 15 
W-sec/cm 2 . The erasure time with this dosage is approx- 
imately 15 to 20 minutes using an ultraviolet lamp with a 
12,000 nW7cm2 power rating. The 8741 should be placed 
within one inch of the lamp tubes during erasure. Some 
lamps have a filter on their tubes which should be 
removed before erasure. 



A.C. TIMING SPECIFICATION FOR PROGRAMMING 

T A = 25°C ±5°C, V cc = 5V ±5%, V DD = 25V ±1V 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


tAW 


Address Setup Time to RESET t 


4tcy 








tWA 


Address Hold Time After RESET t 


4tcy 








tDW 


Data in Setup Time to PROG 1 


4tcy 








tWD 


Data in Hold Time After PROG I 


4tcy 








tPH 


RESET Hold Time to Verify 


4tcy 








tVDDW 


Vdd 


4tcy 








tVDDH 


Vdd Hold Time After PROG 1 











tpw 


Program Pulse Width 


50 


60 


MS 




tTW 


Test Setup Time for Program Mode 


4tcy 








tWT 


Test Hold Time After Program Mode 


4tcy 








tDO 


Test to Data Out Delay 




4tcy 






tww 


RESET Pulse Width to Latch Address 


4tcy 








tr, tf 


Vdd and PROG Rise and Fall Times 


0.5 


2.0 


MS 




tCY 


CPU Operation Cycle Time 


5.0 




MS 




tRE 


RESET Setup Time Before EA t 


4tcy 









Note: If TEST is high, t D0 can be triggered by RESET 1. 

D.C. SPECIFICATION FOR PROGRAMMING 

T A = 25°C ±5°C, V cc = 5V ±5%, V DD = 25V ± 1V 



Symbol 


Parameter 


Min. 


Max. 


Unit 


Test Conditions 


Vdoh 


Vdd Program Voltage High Level 


24.0 


26.0 


V 




Vddl 


Vdd Voltage Low Level 


4.75 


5.25 


V 




VPH 


PROG Program Voltage High Level 


21.5 


24.5 


V 




VPL 


PROG Voltage Low Level 




0.2 


V 




Veah 


EA Program or Verify Voltage High Level 


21.5 


24.5 


V 




Veal 


EA Voltage Low Level 




5.25 


V 




Idd 


Vdd High Voltage Supply Current 




30.0 


mA 




IPROG 


PROG High Voltage Supply Current 




16.0 


mA 




lEA 


EA High Voltage Supply Current 




1.0 


mA 
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SUPPORT PRODUCTS 



Intellec®, Prompt 48™, MCS-48™ 

Microcomputer Design Aid 8-1 

Intellec® Microcomputer Development System .. 8-7 
MCS-48™ Diskette-Based Software 

Support Package 8-12 

MDS-48-ICE8048 In-Circuit Emulator 8-14 

8021 Emulation Board 8-19 
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INTELLEC PROMPT 48 
MCS-48 MICROCOMPUTER DESIGN AID 



Complete low cost design aid and 
EPROM programmer for revolutionary 
MCS-48 single component computers 

Simplifies microcomputing, allowing user 
to enter, run, debug, and save machine 
language programs with calculator-like 
ease 

Utilizes two removable 8-bit MCS-48 
CPUs 

— 8748 CPU with erasable, reprogram- 
mable on-chip program memory 

— 8035 CPU with off-chip program 
memory 

1K-byte erasable, reprogrammable on- 
chip (8748), expandable program mem- 
ory, 1K-byte RAM in PROMPT system 

64 bytes RAM on-chip, expandable 
register memory 



256 bytes expandable RAM data memory 
in PROMPT system 

27 on-chip TTL compatible expandable 
I/O lines 

On-chip clock, internal timer/event 
counter, two vectored interrupts, eight 
level stack control 

Single +5V DC system power 
requirement 

Integral keyboard and displays (no tele- 
typewriter or CRT terminal required) 

Extensive PROMPT 48 monitor, allowing 
system I/O, bus, and memory expansion 

Compatible with Intellec microcomputer 
development systems 

Includes comprehensive design library 



The Intellec Prompt 48 MCS-48 Microcomputer Design Aid is a low cost, fully-assembled design aid for the revolu- 
tionary 8748 single component microcomputer. PROMPT 48 simplifies the programming of MCS-48 systems — pro- 
grams may be entered and debugged with calculator-like ease on the large, informative display and keyboard panel. 
The comprehensive design library with tutorial manual is ideal for newcomers to microcomputing. PROMPT 48's 
panel connector allows easy access to I/O ports and system bus. Thus users can expand program memory beyond the 
1K bytes provided internally. PROMPT 48 can serve as an economical 8748 Specialized PROM Programmer (SPP) 
peripheral in Intellec microcomputer development systems. 




Intel, Intellec, INSITE, Library Manager, MCS, MEGACHASSIS, MIUIOAMI'. I'HOMPT, ,-SCOPE, MULTIBUS, RMX/80, UPI-41, ICE, and iSBC are trademarks of Intel Corporation. 
© Intel Corporation, 1978 8-1 
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FEATURES 

Single Component Computer 

The 8748 is the first microcomputer fully integrated on 
one component. All elements of a computing system are 
provided, including CPU, RAM, I/O, timer, interrupts, and 
erasable, reprogrammable nonvolatile program memory. 

Programming Socket 

PROMPT'S programming socket programs this revolu- 
tionary "smart PROM" — the 8748 — in a highly 
reliable, convenient manner. A fail-safe interlock en- 
sures the device is properly inserted before applying 
programming pulses. Each location may be individually 
programmed, one byte at a time. A read-before-write 
programming algorithm prevents device damage by in- 
advertently programming unerased memory. 

MCS-48 Processors 

The execution socket accepts either an 8035 or an 8748 
MCS-48 processor. Both are supplied with each 
PROMPT 48, and either can serve as heart of the 
PROMPT system. There are no processors within the 
PROMPT 48 mainframe, which instead contains monitor 
ROM and RAM, user RAM, peripherals, drivers, and 
sophisticated control circuitry. Once a processor is 
seated in the execution socket and power is applied, the 
PROMPT system comes to life. Various access modes 
may be selected such as program execution from 
PROMPT system RAM, or from on-chip PROM. Thus pro- 
grams may first be executed from PROMPT RAM with 
the 8035 processor. When debugging is complete, the 
8035 (execution socket) processor can program the 8748 
(programming socket) processor. Finally, a pro- 
grammed 8748 processor may be exercised by itself 
from the execution socket. The execution socket pro- 
cessor runs either monitor or user programs. 

System Monitor 

The system reset command initializes the PROMPT 
system and enters the monitor. The monitor interrupt 
command exits a user program gracefully, preserving 
system status and entering the monitor. The user inter- 
rupt command causes an interrupt only if the PROMPT 
system is running a user program. A comprehensive 
system monitor resides in four 1K-byte read only 
memories. It drives the PROMPT keyboard and displays 
and responds to commands and functions. The top 16 
bytes of on-chip program memory must be used by the 
PROMPT system to switch between monitor and user 
programs. It requires one level of the MCS-48 eight-level 
stack. 

Commands 

PROMPT 48's commands are grouped and color-coded 
to simplify access to the 8748's separate program and 
data memory. Registers, data memory, or program mem- 
ory, may be examined and modified with the examine 
and modify commands. Then either the next or previous 
register and memory locations may be accessed with 
one keystroke. Programs may be exercised in three 
modes. The go no break (GO NO BREAK) runs in real 
time. The go with break (GO WITH BREAK) mode is not 



real time — after each instruction the MCS-48 program 
counter is compared against pending breakpoints. If no 
break is encountered, execution resumes. The go single 
step (GO SINGLE STEP) mode exercises one instruction 
at a time. Commands are like sentences, with param- 
eters separated by NEXT. Each command ends with 
□ EXECUTE/END. In addition to the PROMPT basic 
commands, thirteen functions simplify programming. 
Each is started merely by pressing a hex data/function 
key and entering parameters as required, as shown in 
Table 1. 
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Cable Interface 

An optional cable, PROMPT-SER, directly connects the 
PROMPT system to virtually any terminal via a rear ac- 
cess slot. Another cable, PROMPT-SPP, allows pro- 
grams and data to be downloaded from the Intelllec 
microcomputer development system to the PROMPT 
system for debugging. 










Key 


Function 


Operation 





Port 2 map 


Allows specification of direction of each pin 
on port 2. Port 2 is multiplexed to address 
external program memory and expand I/O. 
Thus it must be buffered; the P2 map com- 
mand establishes the direction of buffering. 


a 


Program EPROM 


Programs 8748 EPROMs. 


H 


Byte search 
(with optional 
mask) 


Sweeps through register, data, or program 
memory searching for byte matches. Start- 
ing and ending memory addresses are spe- 
cified. 


CE 


Word search 
(with optional 
mask) 


Sweeps through register, data, or program 
memory searching for word matches. Start- 
ing and ending memory addresses are spe- 
cified. 


B 


Hex calculator 


Computes hexadecimal sums and differ- 
ences. 


S 


8748 program 
for debug 


Similar to program EPROM, but ensures that 
the top of program memory contains moni- 
tor re-entry code for debugging. 


E 


Compare 


Verifies any portions of EPROM program 
memory against PROMPT memory. 


a 


Move memory 


Allows blocks of register, data, or program 
memory to be moved. 


a 


Access 


Specifies one of six access modes for PRO- 
MPT 48. For example EPROM, PROMPT 
RAM, or external program memory, and a 
variety of input/output options may be 
selected. 


in 


Breakpoint 


Allows any or all of the eight breakpoints to 
be set and cleared. 


ii 


Clear 


Clears portions of register, data, or program 
memory. 


[i 


Dump 


Dumps register, data, or program memory to 
PROMPT'S serial channel: for example, a 
teletypewriter paper tape punch. 


n 


Enter 


Enters (reads) register, data, or program 
memory from PROMPT'S serial channel. 


s 


Fetch 


Fetches programs from EPROM to PROMPT 
RAM. 



Table 1. PROMPT 48 Commands and Functions 



Access 

Easy access to the pins of the executing processor is 
provided via the I/O ports and bus connector. Only the 
EA external access, SS single step, and X1, X2 clock in- 
puts are reserved for the PROMPT system. 



Expansion 

Program or data memory may be expanded beyond that 
provided on-chip or in the PROMPT system. I/O ports 
may be expanded, as with the 8243, or peripheral con- 
trollers may be memory-mapped. The I/O ports and Bus 
connector allows the execution socket processor to be 
directly interfaced to prototype systems, yet be con- 
trolled from the PROMPT panel. 



Control 

The command/function group panel keyboard and dis- 
plays completely control PROMPT 48 — a teletypewriter 
or CRT terminal is not needed. A hyphen prompting 
character appears whenever a command or function can 
be entered. Addresses and data are shown whenever 
examining registers and memory. Parameters for com- 
mands and functions are also shown. 
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FUNCTIONAL DESCRIPTION 

"PROMPT" stands for PROgraMming Tool. It is a pro- 
grammer for 8748 EPROMs, and a versatile aid for 
debugging MCS-48 programs. Programs can be entered 
via its integral panel keyboard, programming socket, or 
serial channel. Almost any terminal can be interfaced to 
the serial channel, including a teletypewriter, CRT, or an 
Intellec microcomputer development system. Intellec 
PROMPT 48 simplifies the programming of MCS-48 
systems. Like the 8748 it is radically new, highly in- 
tegrated, and expandable. Like the MCS-48 family, it is 
low cost, and ideal for small applications and programs. 
It is a design aid, not a development system with 
sophisticated software and peripherals. 

MCS-48 Processors 

PROMPT 48 comes complete with two of Intel's revolu- 
tionary MCS-48 processors: an 8748-4 Single Compo- 
nent 8-Bit Microcomputer and and 8035-4 Single Compo- 
nent 8-Bit Microcomputer. Advances in n-channel MOS 
technology allow Intel, for the first time to integrate into 
one 40-pin component all computer functions: 
8-bit CPU 

1Kx 8-bit EPROM/ROM program memory 
64 x 8-bit RAM data memory 
27 input/output lines 
8-bit timer/event counter 

Performance — More than 90 instructions — each one 
or two cycles — make the single chip MCS-48 equal in 
performance to most multi-chip microprocessors. The 
MCS-48 is an efficient controller and arithmetic pro- 
cessor, with extensive bit handling, binary, and BCD 
arithmetic instructions. These are encoded for 
minimum program length; 70% are single byte opera- 
tion codes, and none is more than two bytes. 
Flexibility — Three interchangeable, pin-compatible 
devices offer flexibility and low cost in development and 
production, as follows: 

8748 — with user-programmable and erasable EPROM 
program memory for prototype and pre-productions 
systems. 

8048 — with factory-programmed mask ROM memory 
for low-cost, high volume production. 
8035 — without program memory, for use with external 
program memories. 

Circuitry — Each MCS-48 processor operates on a 
single +5V supply, with internal oscillator and clock 
driver, and circuitry for interrupts and resets. Extra cir- 
cuitry is in the 8048 ROM processor to allow low power 
standby operation. The 64 x 8 RAM data memory can be 
independently powered. 

Compatibility — For systems requiring additional com- 
patibility, the MCS-48 can be expanded with the new 
8243 I/O expander, 8155 I/O and 256-byte RAM, 8755 I/O 
and 2K-byte EPROM, or 8355 I/O and 2K ROM devices. 
MCS-48 processors readily interface to MCS-80/85 
peripherals and standard memories. 

Memory Capacity 

PROMPT 48 is a complete, fully assembled and powered 
microcomputer system including program memory, data 



memory, I/O, and system monitor beyond that available 
on MCS-48 single component computers. 1K bytes of 
PROMPT system RAM serve as "writable program mem- 
ory" — a ROM simulator for the program memory on 
each MCS-48 computer. 256 bytes of PROMPT system 
RAM serve as "external data memory," beyond the 64 
register bytes on each MCS-48 computer. Users may fur- 
ther expand program or data memory via the panel I/O 
ports and bus connector. 

Programming 

Programs written first in assembly language, are 
entered in machine language and debugged with 
calculator-like ease on the large, informative display 
and keyboard panel. Most MCS-48 operations can be 
specified with only two keystrokes. Once entered, 
routines can be exercised one instruction (single step) 
or many instructions at a time. The principal MCS-48 
register — the accumulator — is displayed while single 
stepping. Programs can be executed in real time (GO 
NO BREAK) or with as many as eight different break- 
points (GO WITH BREAK). 

Control 

PROMPT 48 can be fully controlled either by the panel 
keyboard and displays, or remotely by a serial channel. 
Thus a teletypewriter or CRT can be used but neither is 
required. Full remote control by a serial channel means 
users can download and debug programs using the 
PROMPT 48 together with an Intellec microcomputer 
development system. 

Access 

The PROMPT panel I/O ports and bus connector allow 
easy access to all MCS-48 pins except those reserved 
for control by the PROMPT system, namely EA external 
access, SS single step, and X1, X2 clock inputs. 

Optional Expansion 

PROMPT 48 may be expanded beyond the resources on 
both the MCS-48 single component computer and the 
PROMPT system. External program and data memory 
may be interfaced and input/out ports added with the 
8243 I/O expander. 

Applications 

A specialized PROM Programmer Kit, the PROMPT-SPP, 
allows PROMPT 48 to serve as an economical 8748 
Specialized PROM Programmer peripheral in Intellec 
microcomputer development systems. The PROMPT- 
SPP cable plugs directly into the rear panel of the Intel- 
lec microcomputer development system, as shown in 
Figure 1. 




Figure 1. PROMPT 48 used as on Intellec Microcom- 
puter Development System Peripheral 
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Documentation 

The PROMPT 48 manual includes chapters for the 
reader with little or no programming experience. Topics 
treated range from number systems to microcomputer 
hardware design. A novel, unifying set of tutorial 
diagrams — MICROMAPS — simplify microcomputer 



concepts. PROMPT'S handy, pocket-sized reference 
cardlet can be affixed to the mainframe. Programming 
pads aid in the organization and documentation of pro- 
grams. These features, plus a comprehensive design 
library of manuals, articles, and application notes, 
make the Intellec PROMPT 48 ideal for the newcomer to 
microcomputing. 



SPECIFICATIONS 

Timing 

Basic Instruction — 2.5 ^s 
Cycle Time — t CY = 2.5 us 
Clock- 6 MHz ± 0.1% 

Memory Bytes 

The 8748 contains 64 bytes of register memory, no ex- 
ternal data memory, and 1024 bytes of RAM program 
memory. The PROMPT system provides 256 bytes of ex- 
ternal data memory, and 1024 bytes of RAM program 
memory. PROMPT RAM program memory can be used 
in place of the on-chip EPROM program memory; thus 
programs less than 1024 bytes may be designed. For 
larger programs additional memory can be directly in- 
terfaced to the MCS-48 bus via the PROMPT panel I/O 
ports and bus connector. 

Memory Configuration 



Memory 


Maximum 


On Chip 


In PROMPT 48 


Register 
Data 

Program 


64 
3328 
4096 


64 



1024 EPROM 




256 

1024 RAM 



I/O Ports 

All MCS-48 I/O ports are accessible on the PROMPT 
panel connector. 

Bus — A true bidirectional 8-bit port with associated 
strobes. If the bidirectional feature is not needed, bus 
can serve as either a statically latched output port or a 
non-latching input port. Input and output lines cannot 
be mixed. 

Ports 1 and 2 — Data written to these 8-bit ports is 
latched and remains unchanged until written. As inputs 
these lines are not latching. The lines of ports 1 and 2 
are called quasibidirectional. A special output structure 
allows each line of port 1 and half of port 2 to serve as an 
input, an output, or both. Any mix of input, output, and 
both lines is allowed. 

TO, T1, and INT — Three pins that can serve as inputs. TO 
can be designated as a clock output. Input/output can 
be expanded via the PROMPT panel connector with a 
special I/O expander (8243) or standard peripherals. 

Reset and Interrupts 

Reset — initializes the PROMPT system and enters the 

monitor. 

Monitor Interrupt — exits a user program gracefully, 

preserving system status and entering the monitor. 



User Interrupt — causes an interrupt only if the 
PROMPT system is running a user program. 

The processor traps to location 3-| 6 . The MCS-48 timer/- 
event counter is not used by the PROMPT system and is 
available to the user. Either timer flag or interrupt will 
signal when overflow has occurred. The timer interrupt 
can be used only in the go-no-break (real time) mode. 

EPROM Programming 

PROMPT 48 provides a programming socket to directly 
program 8748s. Programs are loaded into the PROMPT 
RAM program memory via keyboard. EPROM, teletype- 
writer, or other serial interface. A fail-safe interlock 
ensures programming pulses are applied only if the 
device is properly inserted. Inadvertant reprogramming 
is prevented by a read-before-write programming algo- 
rithm. Each location may be individually programmed, 
one byte at a time. 



Panel I/O Ports and Bus Connectors 

All MCS-48 pins, except five, are accessible on the I/O 
ports and bus connector. The five reserved for PROMPT 
system control are EA external access, SS single step, 
X1, X2 crystal inputs, and 5V. Due to internal buffering 
of the MCS-48 bus, access times will be negligibly 
degraded by the PROMPT system. Since MCS-48 pro- 
cessors do not communicate internal address gate 
status, bus data must be driven out if neither PSEN nor 
RD is asserted. 



System Devices 

Both user programs and the PROMPT monitor enjoy ac- 
cess to system devices: serial I/O, panel displays, and 
keyboard. These are memory-mapped to program 
memory addresses beyond 2K. 

Serial I/O — The serial I/O port (data 820 16 , control 821 16 ) 
is defined by software and jumpers for 110 baud, 20 mA 
current loop, but can easily be jumpered for other baud 
rates and RS232C levels. Asynchronous or synchronous 
transmission, data format, control characters, and par- 
ity can be programmed. 

Panel Displays — Eight display ports (data 810-81 7 16 ) 
allow each of the panel displays to be written from user 
programs. Data written on a display device will time out 
after a fixed interval. Displays must be refreshed on a 
polled or interrupt-driven basis. User programs can call 
software drivers which provide this capability. 
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Keyboard — Software is used to debounce the panel 
keyboard (data 810^). The monitor's input routines (see 
Software Drivers) provide this debouncing and can be 
called from user programs. 



Go 



Commands 

Single step 
With break 
No break 

{Register 
Data 
Program 
Open previous/clear/entry H Next 



Memory 



H Execute/End 



Functions 

HI Port 2 map 

E Program EPROM (8748) 

Search (R, D or P)* memory for 1 byte, optional 

mask 

Search (R, D or P) memory for 2 bytes, optional 

mask 

Hexadecimal calculator +,- 

8748 program EPROM for debug 

Compare EPROM with memory 

Move memory (R, D or P) 

Access 

Breakpoint 

Clear memory (R, D or P) 

Dump memory (R, D or P) 

Enter (read) memory (R, D or P) 

Fetch EPROM program memory 



B 



E 

E 

E. 
H 

E 

E 

E 

E 

E 



Panel I/O Ports and Bus Connector — 3M 3425 Flat 
Crimp. A complete cable set including wirewrap header 
for prototyping is Included with each PROMPT. 

Equipment Supplied 

PROMPT 48 mainframe with two MCS-48 processors 

(8748, 8035), display/keyboard, EPROM programmer, 

power supply, cabinet, and ROM-based monitor. 

110 V AC power cable 

110 or 220 V AC 

Fuse 

Panel I/O ports 

Bus connector cable set 

Physical Characteristics 
Height — 5.3 in. (13.5 cm) max 
Width — 17 in. (43.2 cm) 
Depth — 17 in. (43.2 cm) max 
Weight - 21 lb. (9.6 kg) 

Electrical Characteristics 

Power Requirements — either 115 or 230V AC (± 10%) 
may be switch selected on the mainframe. 1.8 amps 
max current (at 125 V AC). 
Frequency — 47-63 Hz 

Environmental Characteristics 

Operating Temperature — 0°C to +40°C 
Non-Oporating Temperature — 20 °C to +65°C 



Note 

*R, D, or P is register, data, or program. 

Software Drivers 

Panel Keyboard In — KBIN, KDBIN 

Panel Display Out — DGS6, DGOUT, HXOUT, BLK, 

REFS, ENREF 

Serial Channel — CI, CO, Rl, PO, CSTS 

Connectors 

Serial I/O — 3M 3462-0001 Flat Crimp/AMP 88106-1 Flat 
Crimp/ Tl H312113 So!der/AMP 1-583485-5 Solder. 



Reference Manuals 

9800402 — Intellec PROMPT 48 User's Manual 

(SUPPLIED) 

9800270 — MCS-48 User's Manual (SUPPLIED) 

9800255 — MCS-48 and UPI-41 Assembly Language 

Programming Manual (SUPPLIED) 

Reference manuals are shipped with each product only 
if designated SUPPLIED (see above). Manuals may be 
ordered from any Intel sales representative, distributor 
office or from Intel Literature Department, 3065 Bowers 
Avenue, Santa Clara, California 95051. 



ORDERING INFORMATION 

Part Number Description 

PROMPT-48 or Intellec PROMPT 48 MCS-48 micro- 
PROMPT-48-220V computer design aid. Complete with 
two MCS-48 processors (8748 and 
8305), EPROM programmer, integral 
keyboard, displays, and system 
monitor in ROM. 

PROMPT-SER Serial cable for connecting PROMPT 
to TTY, CRT. 

PROMPT-SPP Specialized PROM programmer kit lor 

connecting PROMPT 48 to Intellec 
microcomputer development system* 
for EPROM programming. 
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MICROCOMPUTER DEVELOPMENT SYSTEM 



Provides modular microcomputer 
development system for development 
and implementation of MCS-48, MCS-80, 
MCS-85, and Series 3000 microcomputer 
systems 

Intel 8080 microprocessor, with 2 f*s 
cycle time and 78 instructions, controls 
all Intellec functions 

Supports assemblers for 8080, 8085, and 
8748 

16K bytes RAM memory expandable to 
64K bytes 

2K bytes ROM memory expandable with 
6K or 16K PROM/ROM boards 

Provides hardware interface and soft- 
ware drivers for TTY, CRT, line printer, 
high speed paper tape reader, high 
speed paper tape punch, and universal 
PROM programmer 

Eight-level nested, maskable, priority 
interrupt system 



Provides universal bus structure with 
multiprocessor and DMA capabilities 

ROM resident system monitor includes 
all necessary functions for program 
loading, debugging and executing 

RAM resident macroassembler used to 
assemble all 8080 machine instructions 
with full macro and conditional 
assembly capabilities 

RAM resident text editor provides 
powerful string search, substitution, 
insertion, and deletion commands 

ICE (in-circuit emulator) options extend 
Intellec diagnostic capabilities into user 
configured system allowing real-time 
emulation of user processors 

Optional PROM programmer peripheral 
capable of programming all Intel PROMs 

Optional I/O modules expandable in 
groups of four 8-bit input and output 
ports to maximum of 88 ports (all TTL 
compatible) 



The Intellec Microcomputer Development System is a modular microcomputer development system containing all 
necessary hardware and software to develop and implement Intel microcomputers and microcomputer systems. The 
addition of peripherals and options provides the user with a complete in-circuit microcomputer development system 
capability, supporting product design from program development through prototype debugging, production, and field 
testing. 




Intel, Intellec, INSITE, Library Manager, MCS, MEGACHASSIS, MICROAMP, PROMPT, M SCO?E, MULTIBUS, RMX/80, UPI-41, ICE, and ISBC are trademarks of Intel Corporation. 
© Intel Corporation, 1978 8-7 
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FUNCTIONAL DESCRIPTION 

Hardware 

The standard Intellec system consists of four micro- 
computer modules (CPU, 16K RAM memory, front panel 
control, and monitor), an interconnecting printed circuit 
motherboard, power supplies, fans, a chassis, and a 
front panel. Modular expansion capability is provided by 
14 additional sockets on the motherboard. A block dia- 
gram of the Intellec system is shown in Figure 1. 

8080 Microprocessor 

The CPU module uses Intel's powerful NMOS 8-bit 8080 
microprocessor. The 8080's 2 ^s cycle time, 78 instruc- 
tions, unlimited subroutine nesting, vectored interrupt 
and DMA capabilities are fully utilized by the Intellec 
system. Bus control logic resolves bus contention con- 
flicts between the CPU module and other modules capa- 
ble of acquiring control of the bus. The CPU module 
interfaces with a sixteen line address bus and a bidirec- 
tional eight line data bus. 8080 status signals are 
decoded and utilized for memory and I/O operations. An 
eight-level, nested interrupt priority system, complete 
with an interrupt priority push-down stack, resolves con- 
tention for 8080 interrupt servicing. 

Memory 

The RAM memory module contains 16K bytes of Intel 
2107A dynamic RAM operating at full processor speed. 
All necessary address decoding and refresh logic are 
contained on the module. 

Control Functions 

The front panel control module provides system initiali- 
zation, priority arbitration, and real-time clock functions. 
System initialization routines reside in a 256-byte, 
PROM resident, bootstrap loader. An eight-level priority 
arbitration network resolves bus contention requests 
among potential bus masters. A 1 ms interrupt request 
generator, which can be disabled under program con- 
trol, provides real-time clock functions. A 10 ms auto- 
matic time-out feature is also provided to force an inter- 
rupt request if nonexistent memory or I/O is addressed. 

Peripheral Interface 

The monitor module contains the Intellec system moni- 
tor and all Intellec peripheral interface hardware. The 
system monitor resides in a 2K-byte Intel 8316 ROM. The 



module contains all necessary control and data transfer 
circuitry to interface with the standard Intellec periph- 
erals, including a teletype, CRT, high speed paper tape 
reader, high speed paper tape punch, PROM program- 
mer, and line printer. 

Bus Structure 

The Intellec universal bus structure enables several 
CPU and DMA devices to share the bus by operating at 
different priority levels. Resolution of bus exchanges is 
synchronized by a bus clock signal which is derived 
independently from processor clocks. Read/write trans- 
fers may take place at rates up to 5 MHz. The bus struc- 
ture contains provisions for up to 16-bit address and 
data transfers and is not limited to any one Intel micro- 
computer family. 

User Interface 

The Intellec front panel is intended to augment the pri- 
mary user interaction medium: the system console. The 
simplicity of the front panel coupled with the power of 
the system monitor provides an efficient user/lntellec 
interface. The front panel contains eight interrupt 
request switches with corresponding indicators, CPU 
run and halt status indicators, a bootstrap loader 
switch, a reset switch, and a power on switch and 
indicator 

Software 

Resident software provided with the Intellec includes 
the system monitor, the 8080 macroassembler, and the 
text editor. Used together, these three programs sim- 
plify program preparation and speed the debugging 
task. 

System Monitor 

The system monitor provides complete control over 
operation of the Intellec. It is written in 8080 assembly 
language, resides in 2K bytes of ROM memory, and pro- 
vides all necessary functions for program loading and 
execution. Additional commands provide extensive 
debug facilities and PROM programming functions. 
System peripherals may be dynamically assigned either 
via monitor commands or with calls to the system moni- 
tor's I/O subroutines. 

Commands — Programs may be loaded from the reader 
device in either BNPF or hexadecimal format. Utility 
commands aid in executing and checking out programs. 
Typical utility commands are shown in Table 1. 
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Figure 1. Intellec System Block Diagram 
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Command 


Operation 


F 


Initializes memory to constant. 


M 


Moves a block of memory to another 




location. 


D 


Displays memory. 


S 


Modifies RAM memory. 


X(A-F) 


Examines and modifies CPU registers. 


G 


Sets breakpoints. 


G 


Initiates execution at any given address. 


H 


Performs hexadecimal arithmetic. 


X(l) 


Examines and modifies interrupt mask. 



Table 1. Utility Command Functions 

Input/Output — The Intellec system monitor (Intellec 
Series II Microcomputer Development System Monitor) 
contains a powerful and easily expandable input/output 
system built around four logical device types: a console 
device, a reader device, a punch device, and a list 
device. Associated with each logical device may be any 
of four physical devices. The user may control the phys- 
ical device assignment to each logical device with a sys- 
tem command. 

Peripheral Interface — Drivers are provided in the sys- 
tem monitor for the universal PROM programmer, ASR 
33 teletype, high speed paper tape reader, high speed 
paper tape punch, line printer, and CRT. The user may 
write his own drivers for other peripheral devices and 
easily link them to the system monitor. All system 
peripherals may be accessed simply by calling I/O sub- 
routines in the system monitor. In addition, the user 
may dynamically reconfigure his system by monitor 
commands or by calling system subroutines to assign a 
different physical device to each logical device. The 
user may also determine the current system peripheral 
configuration, check I/O status, and determine the size 
of available memory. 

Macroassembler 

The Intellec resident macroassembler translates sym- 
bolic 8080 assembly language instructions into the 
appropriate machine operation codes. It is written in 
PL/M-80, Intel's high level systems programming lan- 
guage and occupies 12K bytes of RAM memory, includ- 
ing space for over 800 symbols. The symbol table size 
may be expanded to a maximum of 6500 symbols by 
adding RAM memory. All I/O in the assembler is done by 
means of the system monitor, enabling the assembler to 
take advantage of the monitor's I/O system. The 
assembler is shipped in hexadecimal object format on 
paper tape or diskette and is standard with each Intel- 
lec. Full macro capability eliminates the errors of hand 
translation, makes it easy to modify programs by adding 
or deleting instructions, eliminates the need to rewrite 
similar sections of one code repeatedly, and simplifies 
program documentation. 

Functions — The assembler performs its function in 
three passes. The first pass builds the symbol table. The 
second pass produces a source listing and provides 
error diagnostics. The third pass produces the object 
code. If the punch and list devices are separate (e.g., a 



high speed punch or printer is available) passes 2 and 3 
may be combined into one pass. 

Object Code — Object code produced by the assembler 
is in hexadecimal format. It may be loaded directly into 
the Intellec for execution and debugging or it may be 
converted by the system monitor to BNPF format for 
ROM programming. 

Conditional Assembly — Conditional assembly permits 
the assembler to include or delete sections of variable 
code, such as the code required to handle optional 
external devices, which may vary from system to 
system. 

Text Editor 

The Intellec text editor is a comprehensive tool for 
entering and correcting assembly language programs 
for the Intel 8080 microcomputer. It is written in 
PL/M-80. It occupies 8K bytes of RAM memory, includ- 
ing over 4500 bytes of workspace. The workspace may 
be expanded to a maximum of 58K bytes by adding RAM 
memory. All I/O in the editor is done through the system 
monitor, enabling the editor to take advantage of the 
monitor's I/O system. The editor is shipped in hexadec- 
imal object format on paper tape or diskette and is stan- 
dard with each Intellec. The editor's command set 
allows the user to manipulate either entire lines of text 
or individual characters within a line. 

Program Entry — Programs may be entered directly 
from the console keyboard or from the system reader 
device. Text is stored internally in the editor's work- 
space, and may be edited with the following commands: 

• string insertion or deletion 

• string search 

• string substitution 

Utility commands — To facilitate the use of these 
editing commands, utility commands are used to 
change positions in the workspace. These include: 

• move pointer by line or by character 

• move pointer to start of workspace 

• move pointer to end of workspace 

Storage — The contents of the workspace may be listed 
to the system console or written to the system list or 
punch device for future use. 



OPTIONAL FEATURES 

The basic Intellec capabilities may be significantly 
enhanced by the addition of optional features, including 
in-circuit emulators, the universal PROM programmer, a 
diskette operating system, input/output modules, RAM/ 
PROM memory, DMA modules, and ROM simulators. 

In-Circuit Emulator 

In-circuit emulators (ICE) extend Intellec diagnostic 
capabilities into user configured systems. The Intellec 
resident ICE processor operates in conjunction with the 
host CPU and interfaces to the user system via an exter- 
nal cable. The ICE processor replaces the user system 
processor providing real-time emulation capability. Res- 
ident memory and I/O may be substituted for equivalent 
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user system elements, thus allowing the hardware 
designer to sequentially develop his system by integrat- 
ing Intellec and user system hardware. Display and 
debug hardware eliminate the need for specially con- 
structed user system equivalents. Augmenting these 
capabilities are such powerful ICE debug functions as 
setting breakpoints, tracing program flow, single step- 
ping, and examining and altering CPU registers and 
memory locations. 

Universal PROM Programmer 

The Intel UPP-103 Universal PROM Programmer is an 
Intellec peripheral capable of programming and verify- 
ing the following Intel PROMs: 1702A, 2704, 2708, 3601, 
3604, 3624, 8702A, 8704, 8708, 8748, and 8755. Program- 
ming and verification operations are initiated from the 
Intellec system console and are controlled by programs 
resident in the Intellec and universal PROM programmer. 

Diskette Operating System 

The addition of a single or dual drive diskette operating 
system significantly reduces program development 
time. An intelligent controller, constructed around 
Intel's powerful Series 3000 computing elements, pro- 
vides diskette interface and control. Intel's software 
operating system (IDOS) in conjunction with the disk- 
ette operating system hardware provides a highly effi- 
cient and easy to use method for assembling, editing, 
and executing programs. 

Input/Output Modules 

Customized user I/O requirements may be satisfied by 
adding I/O modules. Each I/O module contains four 8-bit 



input ports (latched or unlatched), four 8-bit latched out- 
put ports (with adjustable strobe pulses), and eight sys- 
tem interrupt lines. All inputs and outputs are TTL com- 
patible. Optional I/O may be expanded to a maximum of 
44 input and 44 output ports. 

RAM/PROM Memory 

Memory may be expanded by adding RAM or PROM 
modules in user defined combinations. Up to 64K bytes 
of RAM may be added in 16K-byte increments. PROM 
(Intel 8702A) may be added in 256-byte increments by 
adding PROM modules with socket capacity for 6K 
bytes and populating each module with the desired 
mumber of PROMs. Maximum PROM capacity is 12K 
bytes. RAM/PROM memory overlap is resolved by giving 
PROM priority. 

DMA Modules 

DMA (direct memory access) modules work in conjunc- 
tion with the Intellec MDS universal bus to maximize the 
efficiency of data transfers between MDS memory and 
selected I/O devices. Each module contains all the nec- 
essary control and data transfer logic to implement a 
complete DMA channel. 

ROM Simulators 

A ROM simulator composed of high speed bipolar RAM 
emulates Series 3000 bipolar microprogram ROM mem- 
ory. Each ROM simulator module may be used in 
512 x 16 or 1024 x 8 configurations. 



SPECIFICATIONS 

Word Size (Intel 8080 host processor) 

Data — 8 bits 

Instruction — 8, 16, or 24 bits 

Memory Size 

RAM — 16K bytes expandable to 64K bytes using 
optional modules. 

ROM — 2K bytes expandable to 14K bytes in 256-byte 
increments using optional PROM modules. 
PROM — 256 bytes expandable using optional 6K or 
16K modules. 

Total — RAM, ROM, and PROM may be combined in 
user defined configurations up to a maximum of 64K 
bytes. 

Machine Cycle Time 

Host Processor (Intel 8080) — 2.0/^s 

Bus Transfer Rate 

Maximum bus transfer rate of 5 MHz 

System Clocks 

Host Processor (Intel 8080) — Crystal controlled at 2 

MHz ±0.1% 

Bus Clock — Crystal controlled at 9.8304 MHz±0.1% 



I/O Interfaces 

CRT 

Baud Rates: 110/300/600/1200/2400/4800/9600 

(selectable) 

Code Format: 7—12 level code (programmable) 

Parity: Odd/even (programmable) 

Interface: TTL/RS232C (selectable) 

TTY 

Baud Rate: 110 

Input: 10 level Or greater 

Output: 11 level 

Parity: Odd 

Interface: 20 mA current loop 

High Speed Paper Tape Reader 

Transfer Rate: 200 cps 

Control: 2-bit output, 1-bit input 

Data: 8-bit byte 

Interface: TTL 

Punch 

Transfer Rate:75 cps 

Control: 2-bit output, 1-bit input 

Data: 8-bit byte 

Interface: TTL 
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Printer 

Transfer Rate: 165 cps 

Control: 2-bit status input, 1-bit output 

Data: ASCII 

Interface: TTL 

PROM Programmer 

Control: 3 strobes for multiplexed output data 
Data: 8-bit bidirectional 
Interface: TTL 



General Purpose I/O (Optional) 

Input Ports — 8-bit TTL compatible (latched or 
unlatched); expandable in 4 port increments to 44 input 
ports 

Output Ports — 8-bit TTL compatible (latched); expand- 
able in 4 port increments to 44 

Interrupts — 8 TTL compatible interrupt lines 



Interrupt 

8-level, maskable, nested priority interrupt network initi- 
ated from front panel or user selected devices. 



Software Operational Environment 

System Monitor — required hardware: 

Intellec system 

331 bytes RAM memory 

2K bytes ROM memory 

System console 



Macroassembler — required hardware: 

Intellec system 

48K bytes RAM memory 

System console 

Reader device 

Punch device 

List device 

Required software: system monitor 



Text Editor — required hardware: 

Intellec system 

8K bytes RAM memory 

System console 

Reader device 

Punch device 

Required software: system monitor 



Direct Memory Access 

Standard capability on Intellec bus; implemented for 
user selected DMA devices through optional DMA 
module — maximum transfer rate of 2 MHz. 



Memory Access Time 

RAM — 450 ns 

PROM — 1.3 M s using Intel 8708A PROM 



Software Capability 

System Monitor — Devices supported include: 

ASR 33 teletype 

Intel high speed paper tape reader 

Paper tape punch 

CRT 

Printer 

Universal PROM programmer 

4 recognized logical devices 

Macroassembler — Accommodates 800 symbols in 
standard system; automatically expandable with addi- 
tional RAM memory to 6500 symbols maximum; assem- 
bles all 78 8080 machine instructions plus 10 pseudo- 
operators. 

Text Editor — 12K bytes of workspace in standard 
system; automatically expandable with additional RAM 
memory to 58K bytes. 



Tape Format — Hexadecimal object format 



Interface Cables/Connectors 

MDS-920 — High speed punch interface cable 

MDS-930 — Peripheral extension cable 

MDS-940 — DMA cable 

MDS-950 — General purpose I/O cable 

MDS-960 — 25-pin connector pair 

MDS-970 — 37-pin connector pair 

MDS-980 — 60-pin motherboard auxiliary connector 

MDS-985 — 86-pin motherboard main connector 

MDS-990 — 100-pin connector hood 



Emulators 

MDS-ICE-30 — 3001 MCU In-Circuit Emulator 
MDS-ICE-80 — 8080 In-Circuit Emulator 
MDS-ICE-48 — MCS-48 8748 In-Circuit Emulator 
MDS-ICE-85 — MCS-85 8085 In-Circuit Emulator 



Peripherals 

MDS-UPP — UPP-103 Universal PROM Programmer 
MDSPTR — High Speed PaperTape Reader 
MDS-DOS — Diskette Operating System 
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MCS-48 

DISKETTE-BASED SOFTWARE 

SUPPORT PACKAGE 



Extends Intellec microcomputer develop- 
ment system to support MCS-48 
development 

MCS-48 assembler provides conditional 
assembly and macro capability 



Takes advantage of powerful ISIS-II file 
handling and storage capabilities 



Provides assembler output in standard 
Intel hex format 



The MCS-48 Diskette-Based Software Support Package is provided with the Intel ISIS-II system diskette and contains 
both the MCS-48 assembler and the diskette version of the universal PROM mapper. The assembler translates sym- 
bolic 8048 assembly language instructions into the appropriate machine operation codes, and provides both condi- 
tional and macroassembler programming. Output may be loaded either to an ICE-48 module for debugging or into an 
Intellec microcomputer development system for 8748 PROM programming using the universal PROM programmer. 




Intel, Intellec, INSITE, Library Manager, MCS, MEGACHASSIS, MICROAMP, PROMPT, M SCOPE, MULTIBUS, RMX/80, UPI-41, ICE, and iSBC are trademarks of Intel Corporation. 
© Intel Corporation, 1978 8-12 



MCS-48 DISKETTE-BASED SOFTWARE SUPPORT PACKAGE 



FUNCTIONAL DESCRIPTION 

The MCS-48, a software support assembler package, is 
provided with the ISIS-II system diskette and contains 
both the MCS-48 assembler and the diskette version of 
the universal PROM mapper. The MCS-48 assembler 
translates symbolic 8048 assembly language 
instructions into the appropriate machine operation 
codes. The ability to refer to program addresses with 
symbolic names eliminates the errors of hand transla- 
tion and makes it easier to modify programs when 
adding or deleting instructions. Conditional assembly 
permits the programmer to specify which portions of 
the master source document should be included or 
deleted in variations on a basic system design, such as 
the code required to handle optional external devices. 
Macro capability allows the programmer use of a single 
label to define a routine. The MCS-48 assembler will 
assemble the code required by the reserved routine 
whenever the macro label is inserted in the text. Output 
from the assembler is in standard Intel hex format. It 
may be either loaded directly to an in-circuit emulator 
(ICE-48) module for integrated hardware/software de- 
bugging, or loaded into an Intellec development system 
for 8748 PROM programming using the universal PROM 
programmer. A sample assembly listing is shown in 
Table 1. 



ISIS 


8048 MACROASSEMBLER. 


1 


PAGE 1 




LOC 


OBJ 


SEQ 

2 
3 

8 
9 


SOURCE STATEMENT 

DECIMAL ADDITION ROUTINE ADD BCD 
,AT LOCATION BETA TO BCD NUMBER A 
;RESULT IN ALPHA ' LENGTH OF NUMBE 
.PAIRS (ASSUME BOTH BETA AND ALPHA 
.AND HAVE EVEN NUMBER OF DIGITS OR 
.ODDi 
INIT MACRO AUGND.ADDND.CN 

MOV R0. #AUGND 
LI MOV R1. #ADDND 


UMBER 

IS COUNT' DIGIT 
ARE SAME LENG 
MSD ISO IF 



USER SYMBOLS 

ALPHA 0001E BETA 0028 COL 

L1 0102 

ASSEMBLY COMPLETE. NO ERRORS 



SYMBOL CROSS REFERENCE 



MOV 


R0 KALPHA 




R1. HBETA 


MOV 


R2. »COUNT 



Table 1. Sample MCS-48 Diskette-Based 
Assembly Listing 



SPECIFICATIONS 

Operating Environment 
Required Hardware 

Intellec microcomputer development system 

System console 

Intellec diskette operating system 

32K RAM (non-macroassembler) 

48K RAM (macroassembler) 

Optional Hardware 

Universal PROM programmer 

Shipping Media 

Diskette 



Reference Manuals 

9800255 — MCS-48/UPI-41 Assembly Language Pro- 
gramming Manual (SUPPLIED) 

9800236 — Universal PROM Mapper Operator's Manual 
(SUPPLIED) 
9800306 — ISIS-II User's Guide (SUPPLIED) 

Reference manuals are shipped with each product only 
if designated SUPPLIED (see above). Manuals may be 
ordered from any Intel sales representative, distributor 
office or from Intel Literature Department, 3065 Bowers 
Avenue, Santa Clara, California 95051. 



ORDERING INFORMATION 

Product Code Description 

MDS-D48 Diskette-based assembler for MCS-48 

family of microprocessors. 
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ICE-48 
MCS-48 INCIRCUIT EMULATOR 

Emulates 8048, 8748, 8035, and 8021 Microcomputers 



Extends Intellec microcomputer develop- 
ment system debug power to user con- 
figured system via external cable and 
40-pin plug, replacing system MCS-48 
device 

Emulates user system MCS-48 device in 
real time 

Shares static RAM memory with user 
system for program debug 



Eliminates need for extraneous debug- 
ging tools residing in user system 

Collects bus, register, and MCS-48 status 
information on instructions emulated 

Provides capability to examine and alter 
MCS-48 registers, memory, and flag 
values, and to examine pin and port 
values 



Provides hardware comparators for user 
designated break conditions 



Integrates hardware and software efforts 
early to save development time 



The ICE-48 MCS-48 In-Circuit Emulator module is an intellec-resident module that interfaces with any MCS-48 system. 
The MCS-48 family consists of the 8048, 8748, 8035, and 8021 microcomuters. The ICE-48 module interfaces with an 
MCS-48 system through a cable terminating in an MCS-48 pin-compatible plug which replaces the MCS-48 device in 
the system. With the ICE-48 plug in place, the designer has the capability to execute the system in real time while col- 
lecting up to 255 instruction cycles of real-time trace data. In addition, he can single step the system program to 
monitor more closely the program logic during execution. Static RAM memory is available through the ICE-48 module 
to emulate MCS-48 program and data memory. The designer can display and alter the contents of data and replace- 
ment RAM control memory, internal MCS-48 registers and flags, and I/O ports. Powerful debug capability is extended 
into the MCS-48 system while ICE-48 debug hardware and software remain inside the Intellec system. Symbolic refer- 
ence capability allows the designer to use meaningful symbols rather than absolute values when examining and modi- 
fying memory, registers, flags, and I/O ports in this system. 



\ 




Intel, Intellec, INSITE, Library Manager, MCS, MEGACHASSIS, MICROAMP, PROMPT, ^SCOPE, MULTIBUS. RMX/80. UPI-41, ICE, and ISBC are trademarks ot Intel Corporation. 



© Intel Corporation, 1978 



8-14 



ICE-48 



FUNCTIONAL DESCRIPTION 



Debug Capability Inside User System 

The ICE-48 module provides the user with the ability to 
debug a full prototype or production system without 
introducing extraneous hardware or software test tools. 
The module connects to the user system through the 
socket provided for the MCS-48 device in the user 
system. Intellec memory is used for the execution of the 
ICE-48 software. The Intellec console and file handling 
capabilities provide the designer with the ability to com- 
municate with the ICE-48 module and display informa- 
tion on the operation of the prototype system. The 
ICE-48 module block diagram is shown in Figure 1. 

Batch Testing 

In conjunction with the ISIS-II diskette operating 
system, the ICE-48 module can run extensive system 
diagnostics without operator intervention. The designer 
or test engineer can define a complete diagnostic exer- 
cise, which is stored in a file on the diskette. When acti- 
vated with an ISIS-II submit command, this file can 
instruct the ICE-48 module to execute the diagnostic 
routine and store the results in another file on the 
diskette. Results are available to the designer at his 
convenience. In this way, routine diagnostics and long 
term testing may be done without tying up valuable 
manpower. 



Integrated Hardware/Software Development 

The user prototype need consist of no more than an 
MCS-48 socket and timing logic to begin integration of 
software and hardware development efforts. Through 
the ICE-48 module mapping capabilities, Intellec system 
resources can be accessed to replace prototype 
memory. Hardware designs can be tested using the 
system software to drive the final product. Thus, the 
system integration phase, which can be costly when 
attempting to mesh completed hardware and software 
products, becomes a convenient two-way debug tool 
when begun early in the design cycle. 



Real-Time Trace 

The ICE-48 module captures trace information while the 
designer is executing programs in real time. The instruc- 
tions executed, program counter, port values for port 0, 
port 1, and port 2, and the values of selected MCS-48 
status lines are stored for the last 255 instruction cycles 
executed. When retrieved for display, code is disassem- 
bled for user convenience. This provides data for deter- 
mining how the user system was reacting prior to emu- 
lation break, and is available whether the break was user 
initiated or the result of an error condition. For more 
detailed information on the actions of internal registers, 
flags, or other system operations, the user may operate 
in single or multiple step sequences tailored to system 
debug needs. 



USER SOCKET 



11 



CABLE 
BUFFER 



P1 

8748 P2A 

W/INTERIMAL 

MONITOR PGM 

P0 

EA.SS 



INSTR 
SIMULATOR 



BREAK 
TIMING 



TRACE 

MEM 



LATCH 
ADDR 



INTERNAL 
TIMER 



CONTROL PROCESSOR DATA 



ADDR 



DATA 



256-BYTE 

DATA MEM 



INSTR 
DECODE 



i£ 



7T 



4K 




BREAK- 


PGM 




POINT 


MEM 




COMPARE 



77 



CONTROL 
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CONTROL 
PROGRAM 



8080 

CONTROL 
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CONTROL 

SCRATCH 
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Figure 1. ICE-48 Module Block Diagram 
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Memory Mapping 

The 8748 and 8048 contain internal program and data 
memory. Both program and data memory can be 
expanded using external memory devices. 

Internal Memory — When the MCS-48 microcomputer is 
replaced by the ICE-48 socket in a system, the ICE-48 
module supplies static RAM memory as a replacement 
for the internal microcomputer memory. The ICE-48 
module has enough RAM memory available to emulate 
up to the total 4K control memory capability of the sys- 
tem. The ICE-48 module also provides for up to 320 
bytes of data memory. 

External Memory — The ICE-48 module separates 
replacement control memory into 16 256-byte blocks. 
Replacement external data memory consists of one 
256-byte block. Each block of memory can be defined 
separately as supplied by the user system or supplied 
by the ICE-48 module. The user may assign ICE-48 equi- 
valent memory to take the place of external memory not 
yet supplied in his system. During final debug stages 
when external PROM or resident 8748 is used for 
program execution, the designer may load the program 
back to ICE-48 memory to test out program changes 
before reassembly and reprogramming the PROM. 

Symbolic Debugging 

ICE-48 software provides symbolic definition of all 
MCS-48 registers, flags, and selected MCS-48 pins. 
Symbolically defined pseudo registers provide access 
to the sense of MCS-48 flip flops which enable time, 
counter, interrupt, and flag-0/flag-1 options. In addition, 
the user may reference locations in program and data 
memory, or their contents, symbolically. The user sym- 
bol table generated along with the object file during a 
program assembly may be loaded to Intellec memory for 
access during emulation. The user is encouraged to add 
to this symbol table any additional symbolic values for 
memory addresses, constants, or variables he may find 
useful during system debugging. Symbols may be sub- 
stituted for numeric values in any of the ICE-48 com- 
mands. Symbolic reference is a great advantage to the 
system designer. He is no longer burdened with the 
need to recall or look up those addresses of key loca- 
tions in his program that can change with each assem- 
bly. Meaningful symbols from his source program may 
be used instead. For example, the command: 

GO FROM . START TILL XDATA . RSLT WRITTEN 

begins execution of the program at the address refer- 
enced by the label START in the designers assembly 
program. A breakpoint is set to occur the first time the 
microprocessor writes to the external data memory 
location referenced by RSLT. The designer does not 
have to be concerned with the physical locations of 
START and RSLT. The ICE-48 software driver supplies 
them automatically from information stored in the sym- 
bol table. 

Hardware 

The ICE-48 module is a microcomputer system utilizing 
Intel's 8748 microcomputer as its nucleus. The 8748 pro- 



vides the MCS-48 emulation characteristics. The ICE-48 
module uses an Intel 8080 to communicate with the 
Intellec host processor via a DMA port. The 8080 also 
controls an internal ICE-48 bus for intramodule com- 
munication. ICE-48 hardware consists of two PC boards, 
the controller board, and the emulator board, all of 
which reside in the Intellec chassis. A cable interfaces 
the ICE-48 boards to the MCS-48 system. The cable ter- 
minates in a MCS-48 pin compatible plug which 
replaces any MCS-48 device in the user system. The 
ICE-48 module block diagram is shown in Figure 1. 



Real-Time Trace 

Trace Buffer 

While the ICE-48 module is executing the user program, 
it is monitoring port, program counter, data, and status 
lines. Values for each instruction cycle executed are 
stored in a 255 x 44 real-time RAM trace buffer. A reset- 
table timer resident on the controller board counts in- 
struction cycles and provides timing for the trace 
monitor. 



Controller Board 

The ICE-48 module talks to the Intellec system as a 
peripheral device. The controller board receives com- 
mands from the Intellec system and responds through a 
DMA port. Three 15-bit hardware breakpoint registers 
are available for loading by the user. While in emulation 
mode, a hardware comparator is constantly monitoring 
address and status lines for a match to terminate an 
emulation. The breakpoint registers provide a signal 
when a match is detected. The user may disable the 
emulation break capability and use the signal to syn- 
chronize other debug tools. The controller board returns 
real-time trace data, MCS-48 register, flag, and pin 
values, and ICE-48 status information, to a control block 
in the Intellec system when emulation is terminated. 
This information is available to the user through the 
ICE-48 interrogation commands. Error conditions, when 
present, are automatically displayed on the Intellec sys- 
tem console. The controller board also contains static 
RAM memory, which can be used to emulate MCS-48 
program and data memory in real-time. 4K of memory is 
available in 16,256-byte pages to emulate MCS-48 PROM 
or PROM program memory. A 256-byte page of data 
memory is available to access in place of MCS-48 exter- 
nal data memory. The controller board address map 
directs the ICE-48 module to access either replacement 
ICE-48 memory or actual user system external memory 
in 256-byte segments based on information provided by 
the user. 



Emulator Board 

The emulator board contains the 8748 and peripheral 
logic required to emulate the MCS-48 device in the user 
system. A software selectable 6 MHz or 3 MHz clock 
drives the emulated MCS-48 device. This clock can be 
disabled and replaced with a user supplied TTL clock in 
the user system. 
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Cable Card 

The cable card is included for cable driving. It transmits 
address and data bus information to the user system 
through a 40-pin connector which plugs into the user 
system in the socket designed for the MCS-48 device. 

Software 

The ICE-48 software driver is a RAM-based program 
which provides the user with an easy to use command 
language (see Table 1, Table 2, and Table 3) for defining 
breakpoints, initiating real-time emulation or single step 
operation, and interrogating and altering user system 
status recorded during emulation. The ICE-48 command 
language contains a broad range of modifiers to provide 
the user with maximum flexibility in defining the opera- 
tion to be performed. The ICE-48 software driver is avail- 
able on diskette and operates in 32K of Intellec RAM 
memory. 



Command 


Operation 


Enable 
Go 

Step 
Interrupt 


Activates breakpoint and display regis- 
ters for use with go and step commands. 
Initiates real-time emulation and allows 
user to specify breakpoints and data 
retrieval. 

Initiates emulation in single instruction 
increments. Each step is followed by 
register dump. User may optionally tailor 
other diagnostic activity to his needs. 
Emulates user system interrupt. 



Command 


Operation 


Display 


Prints contents of memory, MCS-48 




device registers, I/O ports, flags, pins, 




real-time trace data, symbol table, or 




other diagnostic data on list device. 


Change 


Alters contents of memory, register, out- 




put port, or flag. Sets or alters break- 




points and display registers. 


Map 


Defines memory status. 


Base 


Establishes mode of display for output 




data. 


Suffix 


Establishes mode of display input data. 



Table 2. ICE-48 Interrogation Commands 



Command 


Operation 


Load 


Fetches user symbol table and object 




code from input device. 


Save 


Sends user symbol table and object code 




to output device. 


Define 


Enters symbol name and value to user 




symbol table. 


Move 


Moves block of memory data to another 




area of memory. 


List 


Defines list device. 


Exit 


Returns program control to ISIS-II. 


Evaluate 


Converts expression to equivalent values 




in binary, octal, decimal, and hex. 


Remove 


Deletes symbols from symbol table. 


Reset 


Reinitializes ICE-48 program variables. 



Table 1. ICE-48 Emulation Commands 



Table 3. ICE-48 Utility Commands 



SPECIFICATIONS 

ICE-48 Operating Environment 
Required Hardware 

Intellec microcomputer development system 
System console 

Intellec diskette operating system 
ICE-48 Module 

Required Software 

System monitor 
ISIS-II 

Equipment Supplied 

Printed circuit boards 

Interface cables and buffer module 

ICE-48 software, diskette-based version 

System Clock 

Crystal controlled 6.0 MHz internal, 3.0 MHz internal or 
user supplied TTL external: software selectable. 

Physical Characteristics 

Width — 12.00 in. (30.48 cm) 
Height — 6.75 in. (17.15 cm) 
Depth — 0.50 in. (1.27 cm) 
Weight — 8.00 lb. (3.64 kg) 



Electrical Characteristics 
DC Power Requirements 

V cc = ±5V ±5% 

l cc = 10A max; 7.0A typ 

V DD = +12V ±5% 

Idd = 7 9 mA max; 45 mA typ 

V BB = -10V 

I B b = 20 mA 

Input Impedance — @ ICE-48 user socket pins: 

V, L = 0.8V (max), l, L = 1.6 mA, 
V| H = 2.0V (min), l, H = 40 M A 

For Bus: 

V, L = 0.8V (max), l, L = 250 ^A 

V| H = 2.0V (max), l, H = 20 M A 

Output Impedance — @ ICE-48 user socket pins: 

P1, P2: 

V 0L = 0.5V (max), | 0L = 16 mA 

Voh = V cc (10Kpullup) 

For Bus: 

V 0L = 0.5V (max), l 0L = 25 mA 

V 0H = 3 -65V (min), l 0H = 1 mA 

Others: 

V 0L = °-5V (max), l 0L = 16 mA 

V 0H = 2.4V (max), l 0H = 400 ^A 
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ICE-48 



Environmental Characteristics 



Operating Temperature — 0°C to 40 °C 



Operating Humidity — Up to 95% relative humidity 
without condensation 



Reference Manuals 

9800464 — ICE-48 Operator's Manual (SUPPLIED) 

Reference manuals are shipped with each product only 
if designated SUPPLIED (see above). Manuals may be 
ordered from any Intel sales representative, distributor 
office or from Intel Literature Department, 3065 Bowers 
Avenue, Santa Clara, California 95051. 



ORDERING INFORMATION 
Part Number Description 

MDS-48-ICE 8048, 8748, 8035, 8021 CPU in-circuit 

emulator. Cable assembly and interactive 
diskette software included. 
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MDS-EM1 
8021 EMULATION BOARD 



EPROM functional equivalent of 8021 — single Connects to prototype system through 8021 pin 
component 8-bit microcomputer compatible plug 



Based on 8748 — user programmable/erasable 
EPROM 8-bit computer 



On-card 3.0 MHz or external TTL driven clock 



Operates with ICE-48™ to provide full in-circuit 

debugging of 8021 prototype system Portable 4" X 7" microcomputer circuit assembly 

The MDS-EM1 emulator board is a ready-to-use 4" X 7" microcomputer circuit assembly that emulates the Intel 8021 micro- 
computer. A 12-inch flat-cable assembly connects the board to the 8021 socket in a prototype system. The board is designed 
so that it can be mounted either as a stand-alone unit, or within the prototype assembly. 

The 8021 microcomputer has 1K X 8 mask-programmable ROM program memory and 64 by 8 RAM data memory. The 
MDS-EM1 is controlled by an Intel 8748, with 1 K of EPROM program memory and a 64 byte data memory. The EPROM can 
be programmed and erased repeatedly during hardware and software development. The MDS-EM1 has several ancillary circuits 
that perform the following functions which are specific to the 8021 : 

Zero crossing detector 

Crystal controlled clock/buffer 

Port simulator 

For prototype debugging, the 8748 can be removed from its socket and replaced with a cable to an INTEL ICE-48. When 
used with the MDS-EM1, ICE-48 emulates the 8021 in real-time, or single-steps the 8021 program at the user's command. 
A full range of capabilities for examining and modifying 8021 memory and status are supplied through ICE-48. 
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MDS-EM1 



HARDWARE 

The MDS-EM1 emulation board uses the 8748 to perform the 
emulation. 

P0 SIMULATOR 

Port of the 8021 is a quasi '-bidirectional port. The P0 simulator 
converts the data bus of the 8748 into a quasi-bidirectional port. 

CRYSTAL CONTROL CLOCK BUFFER 

The MDS-EM1 allows user to select an on-board oscillator or a TTL 
clock driven from the 8021 user's prototype system via a Cambion 
Suitcase jumper. 



Jumper 
W1 



Position 



State 



ZERO CROSS DETECTION SIMULATOR 

The zero cross detection simulator enables the 8748's T1 input to 
detect zero-crossings. The circuitry provides a high level signal on 
a positive crossing and a low level signal on a negative crossing of 
zero to the T1 input of the 8748. 

RESET BUFFER 

The 8021 resets on a logic HIGH level signal. However, the 8748 
resets on a logic LOW level, thus an inverter is provided on the 
MDS-EM1 to make the two chips compatible. 

OPTIONAL PULL-UPS 

Resistors are provided to simulate the optional pull-up resistors on 
T1 input and Port of the 8021. A removable resistor pack is used 
on Port 0. The T1 input pull up can be installed by soldering in a 



A-B 
C- D 


On-Board 
External 


50K resistor. 




TTL Clock 


SOFTWARE 



*A bidirectional port which serves as an input port, output port, 
or both even though outputs are statically latched. 



When emulating the 8021 with MDS-EM1, the user must observe the 
8021 instruction set. 



*\ PORT A 
l/ SIMULATOR \f 



H 



CRYSTAL 

CONTROL 

CLOCK 



CROSSING 
DETECTION 
SIMULATORS 



<l 



8021 
CABLE 
PLUG 



1 ON CARD - ' 
| CLOCK | 
I OPTION I 



RESET BUFFER 28 PIN 

, 1 — — , SOCKET 



MDS-EM1 FUNCTION 
DIAGRAM 



MDS-EM1 



SPECIFICATIONS 

OPERATING ENVIRONMENT 

Stand-Alone 

Required Hardware: 
MDS-EM1 emulation board 

In-Circuit Emulation 

Required Hardware: 

MDS-EM1 emulation board 

Intellec Microcomputer Development System configurated 
to support ICE-48 

EQUIPMENT SUPPLIED 

MDS-EM1 printed circuit board 

12" long flat cable terminating in 28-pin plug, pin compatible 
with 8021 

MDS-EM1 Operator's Manual 



SYSTEM CLOCK 

Crystal controlled 3.0 MHz on board or user supplied TTL external 
clock: hardware jumper selectable. 

PHYSICAL CHARACTERISTICS 



Width: 
Height: 
Depth: 
Weight: 



7.0 in. (17.78 cm) 
4.0 in. (10.16 cm) 
0.75 in. (1.91 cm) 
<1.0 lbs. (0.45 kg) 



ELECTRICAL CHARACTERISTICS 

DC Power: 

V cc 5V ± 5o/„ 

l cc 300 mA (max.) 

ENVIRONMENTAL CHARACTERISTICS 

Operating Temperature: — 55°C 

Operating Humidity: up to 95% relative humidity without conden- 



ORDERING INFORMATION 
Part Number Description 
MDS-EM1 8021 Emulation Board 



MCS- 48™ SYSTEM WORKSHOP 



Courses presented at training centers and customer 
facilities. 

Training Centers 

— Boston 

— Chicago 

— Santa Clara 



System demonstrations 

On-site courses tuned to customer requirements. 
Hands-on laboratory sessions reinforce lecture. 
Training center classes limited to 12 attendees. 



Scheduled on a continuing basis throughout the 
year. 

REGISTRATION AND ADDITIONAL INFORMATION: Contact MCD Training at Intel Corporation, Santa Clara, California 
95051 , (408) 246-7501 , or your local Intel sales office. 



This workshop will prepare the student to design and develop a system using the Intel 8048 microprocessor through the use 
of lecture, demonstration and laboratory "hands-on" experience with the Intellec® Development System and PROMPT-48. 

COURSE OUTLINE: 

Day 1 

Orientation 

Introduction 

a. Microprocessor System 

1 . Function 

2. Organization 

3. Programming 

b. 8048 Overview 

1. Functional Sections 

2. Programming Model 

3. Execution Sequence 
Assembly Language Instructions 

a. I/O Instructions 

b. Data Move Instructions 

c. Increment/Decrement Instructions 

d. Branch Instructions 

e. Worksession No. 1 

f. Accumulator Group Instructions 

1. ADD/ADDC 

2. Logicals 
PROMPT-48 

a. Function 

b. Operation 
Laboratory Exercise 
a. Program Entry and Execution 

using PROMPT-48 
Day 2 

Assembly Language Instructions 
a. Accumulator Group Instructions 

1 . Flags 

2. Rotates 



b. Specials (XCH, DA, SWAP) 

c. Worksession No. 2 

d. Subroutines 

1 . Invocation 

2. Stack Operation 

e. Interrupt System 

1 . Description 

2. Service Subroutines 

3. Multiple Source Systems 
Development System 

a. Function 

b. Disk Operating System 
Text Editor and Macro Assembler 

a. Function 

b. Operation 
Laboratory Exercise 

a. Bootstrap Procedures 

b. Create, Edit and Assemble 
Source Program 

c. Execute Program 
Day 3 
System Timing 

a. Basic Timing and Timer 

b. Bus Timing for Peripheral Devices 
Peripherals and Design 

a. Expanding Memory* 

1 . Program Memory (1 , 2K ROMs) 

2. Data Memory (RAMs) 

b. Expanding Ports (8243)* 

1 . Device Characteristics 

2. Software Control of Ports 



c. Combination Chips* 
1.8155 RAM and I/O Chip 

2. 8355,8755 ROM and I/O Chip 

d. Peripheral Interfacing (Parallel)* 
1.8255 Parallel I/O 

2. 8279 Keyboard and Display 
Interface 
—Keyboard Scanning 

Techniques 
—Display Refresh 
Laboratory Exercise 

a. Edit and Assemble Using DOS 

b. Execute Using PROMPT-48 
Day 4 

Peripherals and Design 

a. Peripheral Interfacing (Serial)* 

1. Transmission Formats 

2. Asynchronous Operation 

3. RS232C Interface 

b. A/D and D/A Interfacing* 

1 . Successive 
Approximation A/D 

2. A/D, D/A Chips 

3. A/D Design 
Laboratory Exercises 

a. Edit and Assemble Programs 

b. Execute Programs 

*Each section will consist of a design example 
including schematic, bus loading calculations, 
software and timing. 



PROGRAMMABLE PERIPHERAL CIRCUITS WORKSHOP 



This course will cover the Programmable Peripheral Circuits that are used in a wide variety of application areas such as process 
control, terminals, communications, numerical control, instrumentation, etc. 

Each device is covered in sufficient depth to allow the attendee to define its hardware and software characteristics and 
evaluate its application areas. 



COURSE OUTLINE: 

Day 1 
Introduction 

a. Programmable Concept 

1 . Initialization Commands 

2. Operation Commands 

b. Addressing Methods 

1. Chip Selection 

2. Memory Mapping 

3. I/O Mapping 



8253 Programmable Interval Timer 
8257 Programmable DMA Controller 
8259 Programmable Interrupt Controller 
8279 Programmable Keyboard/Display 
Interface 

a. Chip Descriptions and Applications 

b. Programming Requirements 

c. Design Examples 



Day 2 

8271 Programmable Floppy Disc Controller 

8273 SDLC Protocol Controller 

8275 Programmable CRT Controller 

8155/8355/8755 Combination Memory 

and I/O Ports 

a. Chip Descriptions and Applications 

b. Programming Examples 

c. Design Examples 
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Appendices 

PACKAGING INFORMATION 

AND 
ORDERING INFORMATION 




APPENDICES 



Packaging Information A1-1 

Ordering Information A2-1 



APPENDIX 1 
PACKAGING INFORMATION 





Intel 
Product 
Number 


Standard 
Package Type 


Number 

of 

Pins 


Microcomputers 


8021 
8048 
8049 
8748 
8035 
8039 


P 
D P 
D P 
C 

D P 
D P 


28 
40 
40 
40 
40 
40 


Memory and I/O 
Expanders 


8355 

8755A 

8155/8156 


D P 
C 

D P 


40 
40 
40 


I/O Expander 


8243 


D P 


24 


Standard ROMs 


8308 
231 6E 


D P 
C D P 


24 
24 


Standard EPROM 


8708 
2716 


B 
B 


24 
24 


Standard RAMs 


8111A-4 

8101A-4 

5101 


C D P 
B C P 
B P 


18 
22 
24 


Standard I/O 


8212 
8255 
8251 


D P 
C P 
C D P 


24 
40 
28 


Standard Peripherals 


8205 
8214 
8216 
8226 
8253 
8259 
8278 
8279 


D P 
D P 
D P 
D P 
C 

D P 
D P 
D 


16 
24 
16 
16 
24 
28 
40 
40 


Universal Peripheral 
Interface 


8041 
8741 


D P 
C 


40 
40 



B = Black Ceramic C = Ceramic D = Ceramic DIP P = Plastic 
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PACKAGING INFORMATION 



All dimensions in inches and (millimeters) 



16-LEAD PLASTIC DUAL IN-LINE 
PACKAGE TYPE P 





.325 
-« — MAX.- 
(8.255) 



.110 (2.794I 
.090 (2.286) 



15MIN. 

(0.381) 
020 ( 0.508) 
016 (0.406) 



.010 TYP 
(0.254) 



zfe: 



i .350 I 

h" — (8.890) — »J 



16-LEAD HERMETIC DUAL IN-LINE 
PACKAGE TYPE D 





18-LEAD PLASTIC DUAL IN-LINE 
PACKAGE TYPE P 





£ .015 MIN. 
(0.381) 



.010 TYP 
(0.254) 



4 



.325 
-MAX.- 
(8.255) 



zfe: 



.110 (2.794) 
.090 (2.286) 



I .350 I 

H (8.890) J 
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PACKAGING INFORMATION All dimensions in inches and (millimeters) 



18-LEAD HERMETIC DUAL IN-LINE 
PACKAGE TYPE D 





22-LEAD PLASTIC DUAL IN-LINE 
PACKAGE TYPE P 





PLANE 

.125 (3.175] 
MIN. 



.110 (2.794) 
.090 (2.286) 



.032 TYP 
(0.813) 



015 MIN. 
(0.381) 
.020 (0.508) 
.016 (0.406) 



.010 TYP 
(0.254) 



.425 
- MAX. - 
(10.795) 



'-*/• -Jks 



I .450 I 

\~— (11.430)— J 



22-LEAD HERMETIC DUAL IN-LINE 
PACKAGE TYPE D 





.090 (2.286)' 




J 1*1 1*- 060 TYP 
U- (1524) 



L..015MIN. 
" || (0.381) 

— JU- .020 (0.508) 
.016 (0.406) 




^1-^15° 



PACKAGING INFORMATION All dimensions in inches and (millimeters) 



24-LEAD PLASTIC DUAL IN-LINE 
PACKAGE TYPE P 








SEATING 


WW- 


PLANE 

.125 (3.175) 
MIN. 


_jYY¥ 



.110 (2.794) 
.090 (2.286) 




.625 
- MAX. - 
(15.875) 



.010 TVP 
(0.254) 



4 



=fc 



i .650 j 

U — (16.510)— •) 



24-LEAD HERMETIC DUAL IN-LINE 
PACKAGE TYPE D 





,032 TYP 
(0.813) 



L-015MIN. 
I (0.381) 

"-•JL-.020 10.508) 
.016 (0.406) 




28-LEAD PLASTIC DUAL IN-LINE 
PACKAGE TYPE P 





.125(3.175) 
MIN. 

.110 ( 2.794) 
.090 (2.286) 



.625 
h»- MAX. - 
(15.875) 



£.015 MIN. 
(0.381) 



.010 TYP 
(0.254) 



± 



I .650 

l»— (16.510)— J 
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PACKAGING INFORMATION All dimensions in inches and (millimeters) 



28-LEAD HERMETIC DUAL IN-LINE 
PACKAGE TYPE D 



1.485 (37.719) 





40-LEAD PLASTIC DUAL IN-LINE 
PACKAGE TYPE P 




2.045(51.943) 





cz 


t 

.545 (13.S43) 


.535 (13.589) 

I 
♦ 




.625 
- MAX. - 
(15.875) 



.010 TYP 
(0.254) 



zfc 



I .650 I 

l-> — (16.510) — *l 



40-LEAD HERMETIC DUAL IN-LINE 
PACKAGE TYPE D 



2.080 (52.832) 








.175 (4.445) 
.145 (3.683) H 

js-fEfffnf rri 
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PACKAGING INFORMATION All dimensions in inches and (millimeters) 



24-LEAD HERMETIC DUAL IN-LINE 
PACKAGE TYPE C 



1.215 (30.861) 




~T .020 MIN 
,, (0.508) 

.022 (0.558 ) 
""■"""".OIS (0.381) 



.010 TVP _l^ 
(0.254) ~*J*- 



j .625 j 

1— (15.875)-«-J 



40-LEAD HERMETIC DUAL IN-LINE 
PACKAGE TYPE C 




f_.020 MIN. 
.I (0.508) 

II ^022 (0.5S8) 
.015 (0.381) 



.010 TYP 
(0.254) 



I - 625 

[-•—(15.875)— »-| 
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ORDERING INFORMATION 



Semiconductor components are identified as follows: 
Example: 



M 



1 







1 



Four or five characters 
per device type 



Package Type 

B — Hermetic Package, Type B 

C — Hermetic Package, Type C 

D — Hermetic Package, Type D 

M - Metal Can Package 

P — Plastic Package 

X — Unpackaged Device 



M — Indicates Military Operating 
Temperature Range 



Up to three character 
modifier for power, 
speed, processing, etc. 



Examples: 

P5101L 
C8080A2 

MD3604/C 



CMOS 256 X 4 RAM, low power selection, plastic package, commercial temperature range. 

8080A Microprocessor with 1.5 jjls cycle time, hermetic package Type C, commercial 
temperature range. 



512 X 8 PROM, hermetic package Type D, military temperature range, MIL-STD-883 Level 
C processing.* 

MC8080A/B 8080A Microprocessor, hermetic package Type C, military temperature range, MIL-STD-883 
Level B processing.* 



Kits, boards and systems may be ordered using the part number designations in this catalog. 

The latest Intel OEM price book should be consulted for availability of various options. These may be 
obtained from your local Intel representative or by writing directly to Intel Corporation, 3065 Bowers 
Avenue, Santa Clara, California 95051. 

*On military temperature devices, B suffix indicates MIL-STD-883 Level B processing. Suffix C indicates MIL-STD-883 Level 
C processing. "S" number suffixes must be specified when entering any order for military temperature devices. All orders 
requesting source inspection will be rejected by Intel. 
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CUSTOMER EPROM 

ORDER FORM 

A 



1702A/4702A/8702A Famil 

2708/8708/2704 Famil 

2716, 2758, 8741, 8748, 875! 



Company Phone # 


S# 
STD 
APP 
Date 


For Intel Use Only 


Company Contact Date 

P.O. # Intel Device P/N 




All custom MOS EPROM orders must be submitted on this form. Programming information 
should be sent per the formats described in the Programming Instruction section of the Intel 
Data Catalog. Additional forms are available from Intel. 





MARKING 

The marking will consist of the Intel Logo, the product and package type (B1702A), the 
4-digit Intel pattern number (WWWW), an internal manufacturing traceability code (XXYY), 
and the customer part number (Z....Z). The customer part number is limited to a maximum 
of 9 digits or spaces. 



1702A MARKING 
EXAMPLE 




FLOPPY DISK 

Programming information may be sent on Intel Microcomputer Development System Floppy Disk. When using this input 
medium the floppy disk file name should be indicated in the Customer Part Number Section below. The type of floppy disk 
sent should also be indicated by checking one of the appropriate boxes: 



□ Single Density 



□ Double Density 



CUSTOMER PART NUMBER 

Customer P/N 
(Please Fill-in) 



1. 

2. 

3. 

4. 

5. 

6. 

7. 

8. 

9. 
10. 
11. 
12. 
13. 
14. 
15. 
16. 
17. 
18. 
19. 



1. 

2. 

3. 

4. 

5. 

6. 

7. 

8. 

9. 
10. 
11. 
12. 
13. 
14. 
15. 
16. 
17. 
18. 
19. 



Floppy Disk File Name 
(Please Fill-In) 







































Intel Pattern Number 
(Please Do Not Use) 



1. 

2. 

3. 

4. 

5. 

6. 

7. 

8. 

9. 
10. 
11. 
12. 
13. 
14. 
15. 
16. 
17. 
18. 
19. 
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CUSTOMER 8041, 8048 ROM 

ORDER FORM 

C 



8041, 8048 



Company Phone # 


S# 


For Intel Use Only 


Company Contact Date 




P.O. # Package Type: □ Plastic □ Cerdip 


STD 
APP 
Date 






All custom 8041 and 8048 orders be submitted on this form. Programming information 






should be sent per the formats described in the Programming Instruction section of the Intel 






Data Catalog. Additional forms are available from Intel. 







MARKING 

All devices will be marked as shown at the right figure. The marking will consist of the Intel 
Logo, the product and package type (P8048), the 4-digit Intel pattern number (WWWW), a 
date code (XXYY), and the customer part number (Z....Z). The customer part number is 
limited to a maximum of 9 digits or spaces. 







P8048 
XXYY 



WWWW 
Z....Z 



1 



P8048 MARKING EXAMPLE 



FLOPPY DISK 

Programming information may be sent on Intel Microcomputer Development System Floppy Disk. When using this input 
medium the floppy disk file name should be indicated in the Customer Part Number Section below. The type of floppy disk 
sent should also be indicated by checking one of the appropriate boxes: 



□ Single Density 



□ Double Density 



CUSTOMER PART NUMBER 



Customer P/N 
(Please Fill-In) 
















I l I I l l l l l l I 








l l l l I I l l l l I 

















1. 

2. 

3. 

4. 

5. 

6. 

7. 

8. 

9. 
10. 
11. 
12. 
13. 
14. 
15. 
16. 
17. 
18. 
19. 
20. 



Floppy Disk File Name 
(Please Fill-in) 









































Intel Pattern Number 
(Please Do Not Use) 



1. 

2. 

3. 

4. 

5. 

6. 

7. 

8. 

9. 
10. 
11. 
12. 
13. 
14. 
15. 
16. 
17. 
18. 
19. 
20. 
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intel 



INTEL CORPORATION, 3065 Bowers Avenue, Santa Clara, California 95051 (408) 987-8080 

CUSTOMER 8021 ROM 

ORDER FORM 

I 



Company 



Company Contact 
P.O. No 



Phone No. 
Date 



Package Type: o Plastic o Cerdip 



All custom 8021 orders must be submitted on this form. Programming information should be 
sent in the form of computer punched cards or punched paper tape per the formats described 
in the Programming Instruction section of the Intel Data Catalog. 8748's may also be used to 
input programming information for the 8021. Additional forms are available from Intel. 



For Intel Use Only 



SNo. 
STD. 
APP- 



DATE 



MARKING 

All devices will be marked as shown at the right figure. The marking will consist of the Intel 
Logo, the product and package type (P8021), the 4-digit Intel pattern number (WWWW), a 
date code (XXYY), and the customer part number (Z....Z). The customer part number is 
limited to a maximum of 9 digits or spaces. 



I 



P8021 WWWW 

XXYY Z....Z 



P8021 MARKING EXAMPLE 



CUSTOMER PART NUMBER 

Customer P/N 

(Please Fill-in) 

I I I I I I I I 



Intel Pattern Number 

(Please Do Not Use) 



I I I I I 



I/O Mask Options 

Specify the desired connection for each I/O line on Port and for the T1 input by marking only one box for each pin. 

OPTIONAL PULLUP RESISTOR 

Port 0: Y 

Option 1 deletes the pullup resistor on the I/O line < 

providing true open drain outputs. 1 

Option 2 includes the pullup resistor on the I/O line lo 

providing a quasi-bidirectional line. 1 



PIN 


OP1 
1 


HON 
2 


POO 4 






P01 5 






P02 6 






P03 7 






P04 8 






P05 9 






P06 10 






P07 11 






T1 13 







—I 



Option 1 deletes the pullup resistor for use as a zero 
cross detection input. 

Option 2 includes the pullup resistor for use with an 
external switch or standard TTL. 



OPTIONAL PULLUP RESISTOR 



I PIN t -t-f^o— f>o— 
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INTEL CORPORATION, 3065 Bowers Avenue, Santa Clara, California 95051 (408) 987-8080 



CUSTOMER 8022 ROM 

ORDER FORM 

J 



Company 



Company Contact 
P.O. No. 



Phone No.. 
Date 



Package Type: aplastic D Cerdip 



All custom 8022 orders must be submitted on this form. Programming information should be 
sent in the form of computer punched cards or punched paper tape per the formats described 
in the Programming Instruction section of the Intel Data Catalog. 8755's may also used to 
input programming information for the 8022. Additional forms are available from Intel. 



For Intel Use Only 



SNo. 
STD. 
APP_ 



DATE 



MARKING 

All devices will be marked as shown at the right figure. The marking will consist of the Intel 
Logo, the product and package type (P8022), the 4-digit Intel pattern number (WWWW), a 
date code (XXYY), and the customer part number (Z....Z). The customer part number is 
limited to a maximum of 9 digits or spaces. 



P8022 



XXYY 



WWWW 



Z....Z 



P8022 MARKING EXAMPLE 



CUSTOMER PART NUMBER 

Customer P/N 

(Please Fill-in) 

I I I I I I I I 



Intel Pattern Number 

(Please Do Not Use) 



I/O Mask Options 

Specify the desired connection for each I/O line on Port and for the T1 input by marking only one box for each pin. 

OPTIONAL PULLUP RESISTOR 

Port 0: J 

Option 1 deletes the pullup resistor on the I/O line < 

providing true open drain outputs. 1 

Option 2 includes the pullup resistor on the I/O line |p 

providing a quasi-bidirectional line. 1 



PIN 


OP1 
1 


riON 

2 


POO 10 






P01 11 






P02 12 






P03 13 






P04 14 






P05 15 






P06 16 






P07 17 






T1 19 







—It 



Option 1 deletes the pullup resistor for use as a zero 
cross detection input. 

Option 2 includes the pullup resistor for use with an 
external switch or standard TTL. 



OPTIONAL PULLUP RESISTOR 
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I. PROM AND ROM INPUT FORMATS 

A. Acceptible Formats 

Intel can accept programming and masking information for PROMs, EPROMs, or ROMs in the form of floppy disk, punched 
paper tape, a master device from which to copy, or computer punched cards. The allowable formats are given in Table 1. The 
preferred formats for the paper tape and computer card input media are the Intel Intellec Hex and BPNF since these formats 
are defined to allow detection of errors. 

It is desirable that two, preferably different, input media for each customer code be sent so Intel can perform a code verifica- 
tion to detect any errors between the two inputs. This procedure, if followed, can avoid errors due to a mispunched tape/card 
or sending a defective or improper master device. 

All orders must be accompanied by a customer PROM/ROM order form. A copy of the form is contained in this section and 
additional copies are available from Intel Literature Department, 3065 Bowers Ave., Santa Clara, California 95051. 



Table I. Acceptable Formats 



Floppy Disk 


Paper Tape 


Computer Card 


Master Device 


• Intel Microcomputer 


• Intellec Hex 


• Intellec Hex 


• Same Density and 


Development System 






Pin Compatible 


Single or Double 


• BPNF 


• PN 


to Device which 


Density Disk 






is to be Pro- 




• Hex 




grammed. 



A1. Logic Levels 

All data field for Intel's EPROMs/PROMs/ROMs are positive logic. The only exceptions are the 4001 and 4308 ROMs which 
use negative logic. For the 4001/4308, an "0" is a high output and a "1" is a low output. Consequently, because the BPNP 
format specifies the voltage level at the output of the device, it is necessary to input an "0" and "1" in the 4001/4308 in- 
struction code as a "?" and "N" respectively. However, for the Hex format, the 4001/4308 input should be specified accord- 
ing to the instruction code logic state, i.e., a "1" or "0." The below example shows the corresponding input for 4001 instruc- 
tion codes. For comparison, the input for an 8080A is also given as an example. 

1. 4001 Instruction Code 



4001 
Instruction 
Mnemonic 


4001 

Instruction 

Code 


Intellec Hex 

Or Non-lntellec 

Hex Input 


BPNF 
Input 


NOP 


0000 0000 


00 


BPPPPPPPPF 


WRM 


1110 0000 


E0 


BNNNPPPPPF 



2. 8080A Instruction Code 





Instruction 
Mnemonic 


Instruction 
Code 


Intellec Hex 

Or Non-lntellec 

Hex Input 


BPNF 
Input 


JMP 


1100 0011 


C3 


BPPNNNNPPF 


Push D 


1101 0101 


D5 


BPPNPNPNPF 
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B. Paper Tape Format 

The paper tape which should be used is 1" wide paper using 7 or 8-bit ASCII code (such as a Model 33 ASR Teletype pro- 
duces). The three paper tape formats which should be sent are described in Sections B1 through B3. 

B1. Intellec Hex Paper Tape Format 

In the Intel Intellec Hex Format, a data field can contain either 8 or 4-bit data. Two ASCII hexadecimal characters must be 
used to represent both 8 and 4-bit data. In the case of 4-bit data, only one of the characters is meaningful and must be 
specified on the Intel PROM/ROM Order Form. 

Preceding the first data field and following the last data field there must be a leader/trailer length of at least 25 null charac- 
ters. Comments (except for a colon) may be placed on the tape leader. 

The format described below is readily generated by the Intel Intellec Microcomputer Development System or by systems 
programmed by the user. 

1. RECORD MARK FIELD: Frame 

The ASCII code for a colon (:) is used to signal the start of a record. 

2. RECORD LENGTH FIELD: Frames 1 and 2 

The number of data bytes in the record is representated by two ASCII hexadecimal digits in this field. The high-order 
digit is in frame 1. The maximum number of data bytes in a record is 255 (FF in hexadecimal). An end-of-file record 
contains two ASCII zeros in this field. 

3. LOAD ADDRESS FIELD: Frames 3-6 

The four ASCII hexadecimal digits in frames 3—6 give the address at which the data is loaded. The high-order digit is in 
frame 3, the lower-order digit in frame 6. The first data byte is stored in the location indicated by the load address; 
successive bytes are stored in successive memory locations. This field in an end-of-file record contains zeros or the start- 
ing address of the program. 

4. RECORD TYPE FIELD: Frames 7 and 8 

The two ASCII hexadecimal digits in this field specify the record type. The high-order digit is in frame 7. All data 
records are type 0; end-of-file records are type 1. Other possible values for this field are reserved for future expansion. 

5. DATA FIELD: Frames 9 to 9+2* (record length)-1 

A data byte is represented by two frames containing the ASCII characters 0—9 or A— F, which represent a hexadecimal 
value between and FF (0 and 255 decimal). The high-order digit is in the first frame of each pair. If the data is 4-bit, 
then either the high or low-order digit represents the data and the other digit o* the pair may be any ASCII hexadecimal 
digit. There are no data bytes in an end-of-file record. 



B3. .Non-lntellec Hex Paper Tape Format 

For the non-lntellec Hex Format, a data field can contain either 8 or 4-bit data. Two ASCII hexadecimal characters must be 
used to represent both 8 and 4-bit data. In the case of 4-bit data, only one of the characters is meaningful and must be 
specified on the Intel PROM/ROM Order Form. 

Parity is allowed; however, it is not checked. Preceding the first data field and following the last data field there must be a 
leader/trailer length of at least 25 null characters or rubout punches. 

The format requirements are as follows: 

1. The start of the first data field is indicated by a colon. After the last data field, a semicolon must be punched to indi- 
cate the end. All data fields are to be punched in consecutive order, starting with data field 00n (all addresses low). 

2. Two hex characters must be used to represent the data field of both N word x 8-bit and N word x 4-bit devices. For an 
8-bit data field, the high order data is represented by the left justified character of the pair. Either character of the pair 
may be used to represent the word field of a N word x 4-bit device, however, it must be consistent throughout the word 
field. The other character may be any hex character. 

A field of "don't care" data is allowed. Data after a field of "don't care" will be programmed starting at an address 
location enclosed in parentheses. In the following example, data is entered in addresses 00h to 05h, followed with 
"don't care" from addresses 06h to 25h, data being entered again starting at address location 26h, and followed with 
"don't care" data to the last address location. 

|: l j70F2145100FF l |(26)||7B0890F1 M ; 1 



? 



Start Character 



Data Fields from 
Address 00h to 05h 



Address Location 
where Data is to be 
Programmed 



Data Fields from 
Address 26h to 2Ah 



End Character 



3. The x character may be used to rubout any erroneous character(s). The # character may be used to rubout an entire 
line up to the previous carriage return. 

4. Spaces are allowed only between separate word fields. 

5. After each 72 characters, a carriage return followed by a line feed should be punched to allow a print-out of the tape. 

6. Comments must be placed only between the tape leader and the start of the first data field. 

C. Computer Punched Card Format 

The following general format is applicable to the programming information sent on computer punched cards: 

1. An 80 column Hollerith card (interpreted) punched on an IBM 026 or 029 keypunch should be submitted. 

2. A single deck must consist of a Title Card followed by the data cards. There will be N/8 or N/14 data cards for N words 
x 8-bit and N words x 4-bit devices, respectively, in the PN format. 

For the Intellec Hex format, there will be N/32 data cards for both N words x 8-bit and N words x 4-bit devices, and 
one end of file card. 

C1. Intellec Hex Computer Punched Card Format 

Two hex characters must be used to represent data for both a N word x 8-bit and N word x 4-bit device. For the latter, only 
one of the characters is meaningful and must be specified on the Intel PROM/ROM Order Form. The entire data field for all 
bits must be punched even if it is "don't care". 







DECIMAL NUMBER INDICATINC 








THE TRUTH TABLE NUMBER 








NO. OF OUTPUTS 
4 or 8 












Column 


Data 


TITLE CARO 


INTEL 




1 


Punch a T 


DESIGNATION 




P/N 






2-3 


Blank 


CUSTOMER'S 


DIVISION OR 


CUSTOMER'S 






4-28 
29-30 


Customer Company Name 
Blank 




LOCATION 


P/N 








-i i ' 


-, r-"-, r-L-A r- 






31-50 
51-52 


Customer's Company Division or location 
Blank 


/ 1 II 11 1 




•fits >-■ .: N 




1 1 1 1 1 II II 


1 




53-61 


Customer Part Number 


1 III III 


1 II 1 


1 




62-63 


Blank 


|iiii|||uiii|:tiii|to 


M'mi'MlTurinl'iM 


nmTiiliiiiT'mi'iii'iiMMi 




64-72 


Punch the Intel 4-digit basic part number and 
in ( ) the number of output bits, e.g., 2708 




iiiii|iii>.'!i;!in>iiii 


Illllllllllllllllllltlll'l" 






181. 2316 (81. or 3605(41 


immmniinnininmi 


mnminnnnniin 


iiii]in|ii]iii||inii])!i)i 




73-74 
75-76 


Blank 

Chip number for ROMs with programmable 


llllll!li|)|llll|ll)li!!ISli 

iiiitiiiiiiiliiliimiium 
H7r:|i.-iriii:iir;ri!lri|ill 


iiiiiiiiiiiiiiiiiiiiin 


!llllll)SI|lllillll|l|ll!IH 
Iillill IIIIIHH 




77-78 
79-80 


chip select inputs. If not applicable, leave 

blank. 
Blank 
Punch a 2-digit decimal number to indicate 

truth table number. The first truth table 


[,,,„.,,,„,,,,,,„,,,,,,, 


'."!,'."!""!!!!".'"." 


"""'"'"''•"" H ""'"> 






will be 00. second 01. third 02, etc. 
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a. N word x 8-bit device 



Column 



Data 



1 Record mark: A colon is used to signal the 

start of a record. 
2—3 Record length: This is the count of the actual 
data bytes in the record. Column 2 con- 
tains the high order digit of the count, 
Column 3 contains the low order digit. A 
record length of zero indicates end of file. 
All frames containing data will have a 
maximum record length of 10hex bytes 
(16 decimal). 
4—7 Load address: The four characters starting 
addresses at which the following data will 
be loaded. The high order digit of the load 
address is in Column 4 and the low order 
digit is in Column 7. The first data byte is 
stored in the location indicated by the load 
address. Successive data bytes are stored in 
successive memory locations. ROMs con- 
taining more than 16 bytes of data will use 
two or more records or cards to transmit 
the data. Although the load address for the 
beginning record need not be 0000, each 
subsequent load address should be "10h" 
(16 decimals) greater than the last. 
8—9 Record type: A 2-digit code in this field speci- 
fies the type of this record. The high order 
digit of this code is located in Column 8. 
Currently, all data records are type 0. End- 
of-file records will be type 1; they are dis- 
tinguished by a zero RECORD LENGTH 
field (see above). Other possible values for 
this field are reserved for future expansion. 

10-73 Data 

75—75 Checksum: Same as paper tape format. 

76-78 Blank 

79-80 Punch same 2-digit decimal number as in Title 
Card. 



b. N word x 4-bit device 

This format is identical to the previously documented 8-bit hexadecimal format with the following exceptions: 



Column 



Data 



10—73 Each memory location is represented by two 
columns containing the characters 0—9, 
A— F. Since this is 4-bit data, the user must 
indicate which character of each pair is to 
be used as valid data. A single deck must be 
submitted without mixing first and second 
characters of the pair. 
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C2. PN Computer Punched Card Format 

A word field consists of only P's and N's. A punched P will result in an output high level and a punched l\l in an output low 
level. The B and F characters, unlike the paper tape format, are illegal characters. The entire data field for all bits must be 
punched even if it is "don't care". The data field must begin in consecutive order, starting with address (all addresses 
logically low). 



TITLE CARD 
DESIGNATION 



DECIMAL NUMBER INDICATING 
THE TRUTH TABLE NUMBER 
NO. OF OUTPUTS 
4 or 8 
INTEL 



CUSTOMER'S 
COMPANY NAME 



CUSTOMER'S 
DIVISION OR 
LOCATION 



P/N 



CUSTOMER'S 
P/N 



I II II 
I III 

!000|||00100|?00«0|0 



I I I I ! I I I I I I 1 I I ' I I I I 



v: 



iimiiiniumit 
'?:.>! )]jil)lim)|> 

11(11111111114(111 

SS!SSSJ|S|!S5S|SJ< 

m : 1 1 ; m ; ; i u ; r ; 1 1 

i'vl|M!IM|l|IMI 

.r..li|]<!<ii|ii|il 



211121 

)|];n 

II 1(11 

SSS55S 
SS|(«t 

:;m|) 
hum 

1)l|t! 



00000 

1 1 1 1 1 
mill 

3 3 3 3 3 3 

llllll 

SiSSSS 
EtSSSI 

mm 
mm 



I I II I II II 
I II I 

01|0000000030000l 
|l ■ ■ 1 1 1 ■ 1 ■ t ;|i 1 1 

ininmimm 

3)|)3||33.'3|.'|3J 
lllll lllll I I UK 

S|SSSSS51SSS5SSS 
UllSHff il(lt(| 

mimmmm 

HlllillllMIK 1 

!1I!I«I!|>! i«1|! 



OBOsoonooojoooonr j|r otooof !|| 
1 1 1 1 1 1 III 1 1 1 1 1 1 1 1 I I II 1 1 1 1 1 I II 
m m i n; i m 1 1 m 1 1 1 1 1 : m i 

J3333 J'3|!.'i!!'||3333333' 3 J3 
ii ii i ui!|i ii (i i K|i ii i (<; ii 

51 Jl'jSSSSl|l'jiS5S;S|S|V.Si>i 
SI 5 S t S 5 5 5 U S G S f lit 8 f ( ' S ! < S t C 1 

mmm m m I m m m m 



Column 


Data 


1 


Punch a T 


2-3 


Blank 


4-28 


Customer Company Name 


29-30 


Blank 


31-50 


Customer's Company Division or location 


51-52 


Blank 


53-61 


Customer Part Number 


62-63 


Blank 


64-72 


Punch the Intel 4-<li<|it basic part number and 




in ( ) the number o' output bits; e.g., 2703 




(8), 2316 (8). or 3605 (4) 


73-74 


Blank 


75-76 


Chip number foi ROMs with programmable 




chip select inputs. U not applicable, leave 




blank. 


77-78 


Blank 


79-80 


Punch a 2-(li<)it decimal number to indicate 




truth table number. The first truth tabic 




will be 00, second 01, third 02, etc. 



Title Card Format. 



For a IM words X 4-bit organization only, cards 2 and 
those following should be punched as shown. Each card 
specifies the 4-bit output of 14 words. 



DECIMAL WORD 
ADDRESS BEGINNING 
EACH CARD 



MSB— i 
14 DATA FIELDS 



r 



DECIMAL NUMBER 

INDICATING THE 

TRUTH TABLE NUMBER 



X 



FliHi nnt«h FFFF 



1-fF Ffti 



Ntp Kf-n H, 



Ml) Flllfll FFFF MtlFF I liHF 



mi mi mi mi mi mi mi mi mi mi mi mi im mi 

llllll! ' r ' ? 1 '■ 5 1) 1 « J 1 ( » ! « (I « 5 • P r, » n r 5 1 " J » M [ t " « l> « ' " n ' 1 f '■ • 
I II I I I I I I I l n I I I I | I l I || I l I I I I | | | | | || | l | | | | | | | I l | | | l | | |l | | | l l | l i | l l | i l || i I l| ' | | 

niiiiiiiiiiiiiiiiiiiiiiiimiuiiuiiiiiiiuimiiiiiiiiiiiiiimiimiiiiii 

3 3 3 3 J 3 3 3 J J 3 3 3 .' 1 3 3 ] ! J 3 ] 3 J ! 3 3 3 3 3 J 3 ! 1 1 3 3 3 1 3 ) 3 J 1 3 3 J 3 3 i 3 J 3 3 3 3 3 J ! ! 3 3 3 3 1 1 3 3 3 3 J 3 3 3 J 1 1 
IIIIIIIMI III lllll 11(1111 II t < I i :(<! 1111(11 llllll III 111(11 II III llllll ((((III II 
SiSiSiililliniSSSSiSlll^.jll.ll^jSiillililS^lhlSjSiillliiS 1)511; iiilllSi 
; i • S 5 ! • H f St i S ( 1 1 f i i S I S i f ( $ It ( » I i ( I ( ( I ( 1 1 i S i 5 S S ( i i s !' 1 S 1 5 ! t S i • » S i i » i <y i S S « ! ( « l 
ni;;;|;|i;;; ■:;lll|::;:|,-||;!.'j;||;|||i/|;|i;||';: ;HIH;;;;IIH; w||i|;;|, ; 
1 1 ) 1 1 1 ( 1 1 i 1 1 1 • 1 1 1 1 1 1 1 1 i t ! 1 1 1 1 1 Ii 1 i 1 I 1 ! ! 1 [ I II 1 1 ! S I ( M ! ' f II ' ! • J > '1 1 < I • ' M < I ) 1 1 
) ) » J ) < ', 1 ) I J 1 11 1 ) 1 < ) I . < j 1 « j » ; i , ] ) j s ) ) j , , J i , s ; i , , , . , - , , •. • ; , , , .. ■ , , , , i ■ , , 1 



'^ZS 



Column 


Data 


1-5 


Punch the 5 digit decimal equivalent of the 




binary coded location which begins each 




card. The address is right justified, i.e.. 




00000, 00014, 00028. etc. 


6 


Blank 


7-10 


Data Field 


11 


Blank 


12-15 


Data Field 


16 


Blank 


17-20 


Data Field 


21 


Blank 


22-25 


Data Field 


26 


Blank 


27-30 


Data Field 


31 


Blank 


32-35 


Data Field 


36 


Blank 


37-40 


Data Field 


41 


Blank 


42-45 


Data Field 


46 


Blank 


47-b0 


Data Field 


51 


Blank 


52-55 


Data Field 


56 


Blank 


57-60 


Data Field 


61 


Blank 


62-65 


Data Field 


66 


Blank 


67-70 


Data Field 


71 


Blank 


72-75 


Oata Field 


76-78 


Blank 


79-80 


Punch same 2 digit ijeei'nai number as In 




title card. 
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For a N words X 8-bit organization only, cards 2 and 
those following should be punched as shown. Each card 
specifies the 8-bit output of 8 words. 



LSB — i 

MSB -H ^ 



DECIMAL WORD 
ADDRESS BEGINNING 
EACH CARD 



r 



8 DATA FIELDS 



DECIMAL NUMBER 
INDICATING THE 
TRUTH TABLE NUMBER 
irS 



FFFMthF FFHWiKFF FFFNNFFh 'FlitiHFFF KliKMiFFF MtlFFMNKF FNIiFFIUlF' ')<! \ 



llllllll llllllll llllllll llllllll 

10 D JO 00 D »00« 11)0 10010 00 too 10 0)0 10 )HI 
I I I I I I I I I I I I 1 II II I I I I I I I I I I I I I I I I Ml I 

luuiinuuiuuiiuiiii minim ? 

J3 J J] )]] IJllU)] J])]] J]) 13 11! I 331 J 31 j: 
IIIIIUIIillllHIIIIIIIIIIHIIIIIIIII 
SSSllliiiilHIIiSSSllSSlllSSSllSSlISS' 
liiS(>iiiiiti((iiEii(iiiiti;Slii(EE([l 

illmllli/m illlMilliM|i|;i|li i|: 

111 111 llllll! Itllil 1 llll HUH 1 1 ii II i. 

!IIHlllliil1 1 i'i'.''"ni|II'llili1lll l 



llllllll llllllll llllllll llll 


EDlOOlllOOOOOOOOOOOOOOOOOtOOOOO 


1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 


iiiiiuiuiniiuiiimiuiiiii 


]311)33)])3!333 3)11! 


J J 13)313 33 


iiiiiiiniiiiuiiiii 


IMIlli HI 


SlSHIIl55S55lll!SiS 


llll ->J ,5.1 


1 1 1 E 6 1 ( b i i 1 1 i i S 6 E 6 i I 


bEiHi6bli 


IP llll 1 II 


-I'llilllr 


1 1 1 1 1 t 1 1 1 1 1 1 1 1 1 1 1 1 1 1 


IM11HII1 


; •, m m « c. i -, i ] < ) i < s « ; i 


,,,,,,,,,, 



zJ 



Column 


Data 


1-5 


Punch the 5 digit decimal equivalent of the 




binary coded location which begins each 




card. The address is right justified, i.e.. 




00000, GKW08, 000 16, etc. 


6 


Blank 


7-14 


Data Field 


15 


Blank 


16-23 


Data Field 


24 


Blank 


25-32 


Data Field 


33 


Blank 


34-*1 


Data Field 


42 


Blank 


43-50 


Data Field 


51 


Blank 


52-59 


Data Field 


60 


Blank 


61-68 


Data Field 


69 


Blank 


70-77 


Data Field 


78 


Blank 


79-80 


Punch same 2 digit decimal number as in 




title card. 



D. Custom PROM/ROM Order Forms 

All orders for PROMs/ROMs which are to be electrically or mask programmed at Intel must be submitted with the order 
forms shown on the following pages. Additional forms are available from Intel Literature Department, 3065 Bowers Ave., 
Santa Clara, California 95051. 



The order forms for the individual PROMs/ROMs are listed in Table II below. 



Table II 



PROM/ROM 


Order Form 


Part Number 


Number 


MOSEPROMs 


A 


8741,8748,8755 


A 


2316E, 8316A, 8316AL, 2616 


B 


2332, 2364 


B 


8041,8048 


C 


2608, 8308 


D 


8355 


E 


Bipolar PROMs 


F 



II. MOSEPROMs 

A. Erasure Procedure 

As stated in the EPROM related data sheets, the recommended erasure procedure to use with EPROMs is to illuminate the 
window with a UV lamp which has a wavelength of 2537 Angstroms (A). The data sheets specify a distance of 1 inch and 
erase times of 10—45 minutes, depending on the type of device and UV lamp. Actually, the amount of time required to erase 
a device can be concisely stated in terms of the amount of UV energy incident to the window, expressed in Watt-seconds per 
square centimeter (W-sec/cm 2 ). Table III lists the required integrated dosgae (UV intensity X exposure time) for the EPROMs 
currently in production by Intel. 



Table III. Required Erase Energy for Device Types 



Device Type 


2537A Erase Energy 


1702 A/4 702 A 


6 W-sec/cm 2 


2708/8708 


15 W-sec/cm 2 


2716 


15 W-sec/cm 2 


8748 


1 5 W-sec/cm 2 


8755 


1 5 W-sec/cm 2 



The erase energy expressed in Table III includes a guardband to ensure complete erasure of all bits. It is not sufficient to 
monitor "first bit" erasure to determine erasure time, as some other bits in the array may not be erased. 

A1. UV Sources 

There are several models of UV lamps that can be used to erase EPROMs (see Table IV). The model numbers in the table refer 
to lamps manufactured by Ultra Violet Products of San Gabriel, California. In addition, there are several other manufacturers, 
including Data I/O (Issaquah, Wash.), PROLOG (Monterey, Calif.). Prometrics (Chicago, III.), and Turner Designs (Mt. View, 
Calif.). The individual manufacturers should be consulted for detailed product descriptions. Also shown in the table are 
typical erase times for various combinations of Intel PROMs and lamp intensities. 

Table IV. 



Model 


Power Rating 


Minimum Erase Time for Indicated Dosage 
Without a Filter Over the Bulb 


6 W-sec 
1702 A, 
4702A 


15 W-sec 

2708, 8708, 8755 

2716,8748 


R-52 

S-52 

S-68 

UVS-54 

UVS-11 


13000juW/cm 2 

12000MW/cm 2 

12000/iW/cm 2 

5700MW/cm 2 

5500 /iW/cm 2 


7.7 min 

8.3 min 

8.3 min 

17.5 min 

18.2 min 


19.2 min 
20.7 min 

20.7 min 

43.8 min 
45.6 min 



According to the manufacturers, the output of the UV lamp bulbs decrease with age. The output of the lamp should be 
verified periodically to ensure that adequate intensities are maintained. If this is not done, bits may be partially erased which 
will interfere with later programming and/or operation at high temperature. 

For lamps other than those listed, the erase time can be determined by using a UV intensity meter, such as the Ultra Violet 
Products Model J-225. When a meter is used, the intensity should be measured at the same position (distance from the lamp) 
as the EPROMs to be erased. This will require careful positioning to insure that the sensor will receive the same amount of 
UV light that the window of the EPROM will receive. 

The sensors used with most UV intensity meters show reduced output with constant exposure to UV light. Therefore, they 
should not be permanently placed inside the erasure enclosure, they should only be used for periodic measurements. 
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iny 



3065 Bowers Avenue 
Santa Clara, California 95051 
Til: (408) 967-SOBO" 
TWX: 910-338-0026 



MICROCOMPUTER AND MEMORY COMPONENT 
SALES AND MARKETING OFFICES 



TELEX: 34-6372 



U.S. AND CANADIAN SALES OFFICES 



7844 Horseshoe Trail 



Tel: (205) 883-9394 
ARIZONA 

Intel Corp. 



Danbury 06810 
Tel: (203)792-83 
TWX: 710-456-11 



Tel: (617)256-6567 



Poughkeepsle, NewY 
Tel: (914) 473-2303 
TWX: 510-248-0060 



13777 N. Central Expressway 

Suite 405 

Dallas 75243 

Tel: (214) 238-7 " 



Sunnyvale 94066 
Tel: (408) 738-3870 
TWX: 910-339-9279 



900 Jorie Boulevard 
Suite 220 
Oakbrook 60521 
Tel: (312) 325-9510 
TWX: 910-651-5881 



Bloomlngton 55437 
Tel: (612) 835-6722 
TWX: 910-576-2867 



320 Brookes Drive, Suite 104 
Hazelwood 63042 
Tel: (314) 731-5200 
TWX: 910-762-0618 



Tel: (513) B90-5350 
TWX: 810-450-2528 



Chagrln-Bralnard Bldg. 



Tel: (713) 783-2900 

Intel Corp." 

2925 L.B.J. Freeway 

Suite 100 

Dallas 75234 

Tel: (214) 241-9521 

TWX: 910-860-5487 

VIRGINIA 

Glen White Associates 

Lynchburg 24505 
Tel: (804) 384-6920 
Glen White Associates 
Rt. #1, Box 322 



Tel: (408) 257-9880 
Eerie Associates, Inc. 
4805 Mercury Street 
Suite L 

San Diego 92111 
Tel: (714) 278-5441 



3402 N. Anthony Blvd. 
Ft. Wayne 46802 
Tel: (219) 482-2388 



Technical Representatives, I 



). Box 80903 

ittle 98108 

: (206) 762-4824 



TENNESSEE 



Fountain Valley 92708 
Tel: (714) 839-3341 



1121 Ventura Blvd. 



Tel: (319) 393-5510 



Tel: (913)888-0212, 3, & 4 
TWX: 910-749-6412 



Tel: (516) 231-3300 



3 37659 
Tel: (615) 477-8850 
Glen White Associates 



6446 Ridge Lake Road 



Tel: (714) 835-9642 
TWX: 910-595-1114 



57 West Timonlum Road 

Timonlum 21093 

Tel: (301) 252-6360 

Intel Corp." 

57 West Timonium Road 



642 Kreag Road 



70 Chamberlain f 



6000 East Evans Ave. 



TELEX: 97-8289 



EUROPEAN MARKETING OFFICES 



Rue du Moulin a Papier 



TELEX: 270475 



SCANDINAVIA 

Intel Scandinavia A/S* 
Lyngbyve) 32 2nd Floor 
DK-2100 Copenhagen East 

Tel: (01) 18 20 00 



Intel Corporation (U.K.) Ltd.* 

Broadtleld House 

4 Between Towns Road 



46-50 Beam Street 
Nantwich, Cheshire C 1 
Tel: (0270) 62 65 60 
TELEX: 36620 



n Lincoln StrasseSO 



Tel: (06121)74855 



ORIENT MARKETING OFFICES 



JAPAN 


TAIWAN 


Intel Japan Corporation* 


Taiwan Automation Co." 


Flower Hill-Shlnmachl East Bldg. 


2nd Floor. 224 


1-23-9, Shlnmachl, Setagaya-ku 


Nanking East Road 


Tokyo 1 54 


Section 3 


Tel: (03) 426-9261 




TELEX: 781-28426 


Tel: (02)7710940-3 




TELEX: 11942 TAIAUTO 


INTERNATIONAL DISTRIBUTORS 


ARGENTINA 


BELGIUM 


S.I.E.S.A. 


Inelco Belgium S.A. 


Av. Pte. Rogue Saenz Pena 1142 9B 


Avenue Val Duchesse, 3 


1035 Buenos Aires 


B-1160 Brussels 


Tel: 35-6784 


Tel: (02)660 00 12 


AUSTRALIA 


TELEX: 25441 


A.J.F. Systems & Components 


DENMARK 


PTY. LTD. 


Lyngso Komponent A/S 


44 Prospect Rd. 


Ostmarken 4 


Prospect 5082 


2860 Soborg 


South Australia 17005 


Tel: (01)67 00 77 


Tel: 269-1244 


TELEX: 22990 


TELEX: 82635 


Scandinavian Semiconductor 


A.J.F. Systems & Components 


Supply A/S 


PTY. LTD. 


Nannasgade 18 


29 Devlin St. 


DK-2200 Copenhagen N 


Ryde, N.S.W. 2112 


Tel: (01)83 50 90 


Tel: (02) 807-6878 


TELEX: 19037 


TELEX: 24906 




A.J.F. Systems 4 Components 
PTY. LTD. 


FINLAND 

Oy Fintronic AB 


310 Queen St. 


Loennrotinkatu 35D 


Melbourne, Victoria 3000 


SF 00180 


Tel: (03) 679-702 


Helsinki 18 


TELEX: 30270 


Tel: (90) 664 451 


Warburton-Franki (Sydney) Ply. Ltd 


TELEX: 12426 


199 Parramatta Road 


FRANCE 


Auburn, N.S.W. 2114 


Celdis 


Tel: 648-1711, 648-1381 


53, Rue Charles Frerot 


TELEX: WARFRAN AA 22265 


94250 Gentilly 


Warburton-Franki Industries 


Tel: 581 00 20—581 04 69 


(Melbourne) Pty. Ltd. 


TELEX: 200 485 F 


220 Park Street 


Metrologie 


South Melbourne. Victoria 3205 


La Tour d'Asnieres 


Tel: 699-4999 


4, avenue Laurent Cely 


TELEX: WARFRAN AA 31370 


92606 Asnieres 




Tel: 791 44 44 


AUSTRIA 


TELEX; 611 448 F 


Bacher Elektronische Gerate GmbH 


Tekelec Airlronic* 


Meidlinger Hauptstrasse 78 


CitedesBruyeres 


A 1120 Vienna 




Tel: (0222) 83 63 96 


92310 Sevres 


TELEX: (01) 1532 


Tel: (1)027 75 35 




TELEX: 250997 


"Note New Telephone Number 





Hong Kong 
SINGAPORE 

General Engineers Associa 



i Neye Enatachnik GmbH 



TELEX: 484426 



3 Mahatma Gandhi Road 



CABLE: GUNTICO 



TELEX: 39332 



Via Paolo Gaidano, 141 D 

10137 Torino 

TEL: (011) 30 97 097 - 30 97 114 

EledraSSS.P.A." 

Via Giuseppe Valmarana. 63 

00139 Rome, Italy 

Tel: (06) 81 27 290-61 27 324 



Sam Yung Bldg. #303 

71-2 Bukchang - Dong Chung-t" 



Tel: (0711) 7351506 



Hindenburger Strasse 28/29 
3000 Hannover 
Tel: (0511) 852051 



JAPAN 


SOUTH AFRICA 


Pan Electron 


Electronic Building Elements 


No. 1 Higashikata-Machl 


P.O. Box 4609 


Midori-Ku. Yokohama 226 




Tel: (045)471-8811 


Tel: 78 92 21 


TELEX: 781-4773 


TELEX: 30181 


Ryoyo Electric Corp. 


SPAIN 


Konwa Bldg. 




1-12-22, Tsukijl, 1-Chome 


Ronda San Pedro 22 


Chuo-Ku, Tokyo 104 


Barcelona 10 


Tel: (03) 543-7711 


Tel: 301 78 51 


Nippon Micro Computer Co. Ltd. 


TELEX: 51508 IFCE E 


Mutsuml Bldg. 4-5-21 Kojimachl 




Chiyoda-ku, Tokyo 102 


SWEDEN 


Tel: (03) 230-0041 


Nordisk Electron* AB 




S-10380 Stockholm 7 


Inelco Nederland 


Tel: (08) 248340 


AFD Elektronlc 


TELEX: 10547 


Joan Muyskenweg 22 






SWITZERLAND 


Tel: (020) 934824 


IndustradeAG 


TELEX: 14622 


Gemsenstrasse 2 




Postcheck 80 -21190 




CH-8021 Zurich 


W. K. McLean Ltd. 


Tel: (Q1)60 22 30 


103-5 Felton Matthew Avenue 


TELEX: 56788 


Glenn Innes, Auckland 




Tel: 587-037 


UNITED KINGDOM 


TELEX: NZ2763 


Rapid Recall. Ltd. 


NORWAY 


DruryLane 

London WC2H9BS 


Nordisk Elektronik (Norge) A/S 




Tel: (01)379-6741 






Tel: (02) 55 38 93 
TELEX: 16963 


G.E.C. Semiconductors Ltd. 




East Lane 


PORTUGAL 


Wembley HA9 7PP 


Componentes E Electronica LDA 


Tel: (01) 904-9303 


Av. Miguel Bombarda, 133 


TELEX: 923429 


Lisboa 1 


Jermyn Industries 


Tel: 119 45 313 


Vestry Estate 




Sevenoaks. Kent. 




Tel: (0732) 50144 




TELEX: 95142 
Arkwright Road 










RG2 0LS 




Tel: (0734) 85464 




*Field Application Location 



intel 



i. California 950S1 



MICROCOMPUTER AND MEMORY SYSTEM 
SALES AND MARKETING OFFICES 



U.S. AND CANADA SALES OFFICES 



CONNECTICUT 



PENNSYLVANIA (cont.) 



Tel: (203) 7: 
FLORIDA 



1 So. Maltlant 
I: (305) 645-3' 



MASSACHUSETTS 



257 Crescent 
Tel: (617) 894 
MICHIGAN 



Tel: (313) 3 
TELEX: 2 3 



1651 East 4th Street 



Oakbrook 6C 
Tel: (312) 32 



Daylon 45429 
Tel: (513) 435-47 
Lowry & Assoc i a 



ta Associates 



WASHINGTON 



EUROPEAN MARKETING OFFICES 



1-23-9,i 



Ft. Wayne 46802 


Tel: (201) 985-9100 


ES/Chase Compi 


iny 


Seattle 98108 


Tel: (219) 482-238B 


NEW MEXICO 


Se^nS?^!' 




Tel: (206) 762-4824 




















WISCONSIN 

Intel Corp, 

4369 S. Howell Ave 

Milwaukee 53207 


Cedar Rapids 52402 


Tel: (505) 523-0601 


PENNSYLVANIA 

275 Commerce D 








200Olfice Centei 




Tel: (414) 747-0769 


KANSAS 


Albuquerque 671 1 1 


Fort Washington 


19034 


CANADA 


Tel: (505) 292-1212 


Tel: (215) 542-94' 




70 Chamberlain Ave. 










Ottawa, Ontario K1S 1V9 


Tel: (913) 688-0212, 3, & 4 
TWX: 910-749-6412 


NEW YORK 


Q.E.D. Electronic 




Tel: (613) 232-6576 




350 Vanderbllt Motor Pkwy. 


Tel: (215) 674-96! 




Multllek, Inc.* 




Suite 402 














Ottawa, Ontario K2G 0G3 




Tel: (516) 231-3300 






Tel: (813) 226-2365 


CES 

FRANCE 


SCANDINAVIA 


ENGLAND 




GERMANY 


Intel Corporation, S.A.R.L.* 


Intel Scandinavia A/S' 
Lyngbyvej 32 2nd Floor 


Intel Corporation 


(U.K.) Lid.* 


Intel Semiconductor GmbH* 
Seldlatrasse 27 




DK-2100 Copenhagen East 


4 Between Towns 






94528 Rungls Cedex 




Cowley, Oxford OX4 3NB 


Tel: (089) 55 81 41 


Tel: (01) 637 22 21 










TELEX: 270475 




TELEX: 837203 




Intel Semiconductor GmbH 






Intel Corporation 




Abraham Lincoln Strasse 30 












S-16120 Bromma 




re CW5 5LJ 


Tel: (06121) 74855 




Sweden 






TELEX: 04186183 




Tel: (08)93 53 90 


TELEX: 36620 




Intel Semiconductor GmbH 




TELEX: 12261 






D-7000 Stuttgart 80 
Tel: (0711) 7351506 
TELEX: 7255346 


TaTa^AutomatlonCo- 


HONG KONG 

China Electronics 


KOREA 

Koram Digital 




Hindenburger Slrasse 28/29 




Sea Bird House, 9th Floor 


Sam Yung Bldg. 


*303 


Tel: (0511) 852051 
u TELEX: 0923625 


Nanking East Road 


H 2 ' ^8 K n y n n ^ dhamSl^e8, 


71-2 Bjkchang - 


Dong Chung-K 



TELEX: 781-28426 




Tel: (02) 7710940-3 
TELEX: 11942 TAIAUTO 


INTERNATIONAL DISTRIBUTORS 


ARGENTINA 

S.I.E.S.A. 

Av. Pte. Rogue Saenz Pena 1142 

1035 Buenos Aires 

Tel: 35-6784 


9B 


DENMARK 

Lyngso Komponent A/S 
Ostmarken 4 

Tel: (01) 67 00 77 
TELEX: 22990 


A.J.F. Systems & Components 

PTY. LTD. 

44 Prospect Rd. 

Prospect 5082 




Supply A/S 

DK-2200 Copenhagen N 

TELEX: 19037 


Teh'^IM^" 8 170 ° 5 




TELEX: 82635 






A.J.F. Systems & Components 




OyFintronlcAB 
Loennrotinkatu 35D 


Ryde. N.S.W. 2112 
Tel: (02)807-6878 

A.J.F. Systems & Components 




Tel: (90) 664 451 
TELEX: 12426 

FRANCE 


310 Quean St. Melbourne, 




53, Rue Charles Frerot 


Tel: (03) 679-702 
TELEX: 30270 




tS: 5 58° 0020-591 04 69 


Warburton-Franki (Sydney) Pty. 


Ltd 


1 U^rolo^e° ^ F 



GERMANY (cont.) 



CABLE: GUNTICO 
ISRAEL 



Chiyodi 
Tel:(03)i:JU-uu* 

NETHERLANDS 



o Computer < 
Ig, 4-6-21 Ko, 



SWEDEN 

Nordlsk Electron Ik AE 

S-10380 Stockholm 7 
TELEX: 10547 
SWITZERLAND 



Postcheck 60- 



*Field Application Location 



iny 



3065 Bowers Avenue 
Santa Clara, California 95051 
Tel: (408) 987-8080" 
TWX: 910-338-0026 
TELEX: 34-6372 

U.S. AND CANADIAN DISTRIBUTORS 



U.S. AND CANADIAN DISTRIBUTORS 



ALABAMA 

t'Hamilton/Avnet Electronics 

805 Oser Drive NW 

Huntsvllle 35805 

Tel: (205) 533-1170 

Pioneer 

1207 Putman Drive NW 

Huntsville 35805 

Tel: (205) 837-9300 

ARIZONA 

t'Hamilton/Avnet Electronics 
8155 North 21st Street 
Phoenix 85021 
Tel: (602) 275-7851 
Liberty/Arizona 
8155 N. 24th Avenue 
Phoenix 85021 
Tel: (602) 257-1272 
TELEX: 910-951-4282 

CALIFORNIA 

t'Avnet Electronics 

350 McCormick Avenue 

Costa Mesa 92626 

Tel: (714) 754-6111 

Tel: (213) 558-2345 

t'Hamilton/Avnet Electronics 

575 E. Mlddlefield Road 

Mountain View 94040 

Tel: (415)961-8600 

t'Hamilton/Avnet Electronics 

8917 Complex Drive 

San Diego 92123 

Tel: (714) 279-2421 

t* Hamilton Electro Sales 

10912 W.Washington Boulevard 

Culver City 90230 

Tel: (213) 558-2121 

(Cramer/San Francisco 

720 Palomar Avenue 

Sunnyvale 94086 

Tel: (408) 739-3011 

Cramer/Los Angeles 

17201 Daimler Street 

Irvine 92714 

Tel: (714) 979-3000 

(Liberty Electronics 

124 Maryland Street 

El Segundo 90245 

Tel: (213) 322-8100 

Tel: (714) 638-7601 

TWX: 910-348-7140 

tLiberty/San Diego 

8284 Mercury Court 

San Diego 92111 

Tel: (714) 565-9171 

TELEX: 910-335-1590 

tElmar Electronics 

2288 Charleston Road 

Mountain View 94040 

Tel: (415) 961-3611 

TELEX: 910-379-6437 

COLORADO 

tElmar/Denver 
6777 E. 50th Avenue 
Commerce City 80022 
Tel: (303) 287-9611 
TWX: 910-936-0770 
t'Hamilton/Avnet Electronics 
5921 No. Broadway 
Denver 80216 
Tel: (303) 545-1212 

CONNECTICUT 

tCramer/Connecticut 
35 Dodge Avenue 
North Haven 06473 
Tel: (203) 239-5641 
t'Hamilton/Avnet Electronics 
643 Danbury Road 
Georgetown 06829 
Tel: (203) 762-0361 
Harvey Electronics 
112 Main Street 
Norwalk 06851 
Tel: (203) 853-1515 

FLORIDA 

Cramer/E.W. Hollywood 

4035 No. 29th Avenue 

Hollywood 33020 

Tel: (305) 921-7878 

t'Hamilton/Avnet Electronics 

6800 Northwest 20th Ave. 

Ft. Lauderdale 33309 

Tel: (305) 971-2900 

Cramer/EW Orlando 

345 No. Graham Ave. 

Orlando 32814 

Tel: (305)894-1511 

Pioneer 

6220 S. Orange Blossom Trail 

Suite 412 

Orlando 32809 

Tel: (305) 859-3600 

GEORGIA 

tCramer 

6456 Warren Drive 
Norcross 30071 
Tel: (404) 448-9050 

"Note New Telephone Number 



GEORGIA (cont.) 

t'Hamilton/Avnet Electronics 
6700 I 85. Access Road, #11 
Norcross 30071 
Tel: (404) 448-0800 

ILLINOIS 

tCramer/Chicago 
1911 So. BusseRd. 
Mt. Prospect 60056 
Tel: (312) 593-8230 
t'Hamilton/Avnet Electronics 
3901 No. 25th Ave. 
Schiller Park 60176 
Tel: (312) 678-6310 
Pioneer/Chicago 
1551 Carmen Drive 
Elk Grove Village 60006 
Tel: (312) 437-9680 

INDIANA 

tPioneer/lndlana 
6408 Castleplace Drive 
Indianapolis 46250 
Tel: (317) 849-7300 
Sheridan Sales 
8790 Purdue Road 
Indianapolis 46268 
Tel: (317) 297-3146 

KANSAS 

t'Hamilton/Avnet Electronics 
9219 Quivira Road 
Overland Park 6621 5 
Tel: (913) 888-8900 

MARYLAND 

tCramer/EW Washington 
16021 Industrial Drive 
Gaithersburg 20760 
Tel: (301) 948-0110 
t'Hamilton Avnet 
7235 Standard Drive 
Hanover 21076 
Tel: (301) 796-5000 
tPioneer/Washlngton 
9100 Gaither Road 
Gaithersburg 20760 
Tel: (301) 948-0710 
TWX: 710-828-0545 

MASSACHUSETTS 

tCramer Electronics Inc. 
85 Wells Avenue 
Newton 02159 
Tel: (617) 969-7700 
t'Hamilton/Avnet Electronics 
100 E. Commerce Way 
Woburn 01801 
Tel: (617) 933-8000 

MICHIGAN 

tSheridan Sales Co. 
24543 Indoplex Circle 
Farmington Hills 48024 
Tel: (313) 477-3800 
tPloneer/Mlchlgan 
13485 Stamford 
Livonia 48150 
Tel: (313) 525-1800 
t'Hamilton/Avnet Electronics 
32487 Schoolcraft Road 
Livonia 48150 
Tel: (313) 522-4700 
TWX: 810-242-8775 

MINNESOTA 

(Industrial Components 

5280 West 74th Street 

Minneapolis 55435 

Tel: (612) 831-2666 

tCramer/Bonn 

7275 Bush Lake Road 

Edina 55435 

Tel: (612) 835-7811 

t'Hamilton/Avnet Electronics 

7683 Washington Avenue So. 

Edina 55435 

Tel: (612) 941-3801 

MISSOURI 

t'Hamilton/Avnet Electronics 
396 Brookes Lane 
Hazelwood 63042 
Tel: (314) 731-1144 
Sheridan Sales 
110 S. Hwy. 67, Suite 10 
Florissant 63031 
Tel: (314) 837-5200 

NEW JERSEY 

Cramer/Pennsylvania, Inc. 

12SprlngdaleRoad 

Cherry Hill Industrial Center 

Cherry Hill 08034 

Tel: (609) 424-5993 

TWX: 710-896-0908 

t'Hamilton/Avnet Electronics 

218 Little Falls Road 

Cedar Grove 07009 

Tel: (201) 239-0800 

TWX: 710-994-5787 

Cramer/New Jersey 

1 Cardinal Drive 

Little Falls 07424 

Tel: (201) 785-4300 



NEW JERSEY (cont.) 

tHarvey Electronics 

389 Passaic Avenue 

Fairfield 07006 

Tel: (201) 227-1262 

t'Hamilton/Avnet Electronics 

113 Gaither Drive 

East Gate Industrial Park 

Mt. Laurel 08057 

Tel: (609) 234-2133 

TWX: 710-897-1405 

NEW MEXICO 

t'Hamilton/Avnet Electronics 

2524 Baylor Drive, S.E. 

Albuquerque 87119 

Tel: (505) 765-1500 

NEW YORK 

tCramer/Rochester 

3000 Winton Road South 

Rochester 14623 

Tel: (716) 275-0300 

t'Hamilton/Avnet Electronics 

167 Clay Road 

Rochester 14623 

Tel: (716) 442-7820 

Cramer/Syracuse 

6716 Joy Road 

East Syracuse 13057 

Tel: (315) 437-6671 

t'Hamilton/Avnet Electronics 

6500 Joy Road 

E.Syracuse 13057 

Tel: (315) 437-2641 

(Cramer/Long Island 

129 Oser Avenue 

Hauppauge, L.I. 11787 

Tel: (516) 231-5600 

TWX: 510-227-9863 

t'Hamilton/Avnet Electronics 

70 State Street 

Westbury, L.I. 11590 

Tel: (516) 333-5800 

TWX: 510-222-8237 

tHarvey Electronics 

60 Crossways Park West 

Woodbury 11797 

Tel: (516) 921-8700 

NORTH CAROLINA 

tCramer Electronics 

938 Burke Street 

Winston-Salem 27102 

Tel: (919) 725-8711 

Pioneer/Carolina 

2906 Baltic Avenue 

Greensboro 27406 

Tel: (919) 273-4441 

TWX: 510-925-1114 

Hamilton/ Avnet Electronics, Inc 

2803 Industrial Drive 

Raleigh 27609 

Tel: (919) 829-8030 

OHIO 

tSheridan Sales Co. 

2501 Neff Road 

Dayton 45414 

Tel: (513) 223-3332 

tCramer/Cleveland 

5835 Harper Road 

Cleveland 44139 ~ 

Tel: (216) 248-8400 

t'Hamilton/Avnet Electronics 

954 Senate Drive 

Dayton 45459 

Tel: (513) 433-0610 

TWX: 810-450-2531 

(Pioneer/Dayton 

1900 Troy Street 

Dayton 45404 

Tel: (513) 236-9900 

tSheridan Sales Co. 

10 Knollcrest Drive 

Cincinnati 45222 

Tel: (513) 761-5432 

TWX: 810-461-2670 

t Pioneer/Cleveland 

4800 E. 131st Street 

Cleveland 44105 

Tel: (216) 587-3600 

t'Hamilton/Avnet Electronics 

761 Beta Drive, Suite E 

Cleveland 44143 

Tel: (216) 461-1400 

tSheridan Sales Co. 

23224 Commerce Park Road 

Beachwood 44122 

Tel: (216) 831-0130 

OKLAHOMA 

tComponents Specialties, Inc. 

7920 E. 40th Street 

Tulsa 74145 

Tel: (918) 664-2820 

OREGON 

tAlmac/Stroum Electronics 

4475 S.W. Scholls Ferry Rd. 

Portland 97225 

Tel: (503) 292-3534 

PENNSYLVANIA 

tSheridan Sales Co. 

1717 Penn Avenue, Suite 5009 

Pittsburgh 15221 

Tel: (412) 244-1640 

Pioneer/Pittsburgh 

560 Alpha Drive 

Pittsburgh 15238 

Tel: (412) 782-2300 



PENNSYLVANIA (conL) 

Pioneer/Delaware 
141 Gibraltar Road 
Horsham 19044 
Tel: (215) 674-4000 
TWX: 510-665-6778 

TENNESSEE 

Sheridan Sales Co. 
6900 Office Park Circle 
Knoxville 37919 
Tel: (615) 588-5386 

TEXAS 

Component Specialties Inc. 

8330 Burnett Road, Suite 101 

Austin 78758 

Tel: (512) 459-3308 

tCramer Electronics 

13740 Midway Road 

Dallas 75240 

Tel: (214) 661-9300 

t'Hamilton/Avnet Electronics 

4445 Sigma Road 

Dallas 75240 

Tel: (214) 661-8661 

t'Hamilton/Avnet Electronics 

3939 Ann Arbor 

Houston 77063 

Tel: (713) 780-1771 

(Component Specialties, Inc. 

10907 Shady Trail, Suite 101 

Dallas 75220 

Tel: (214) 357-6511 

(Component Specialties, Inc. 

8585 Commerce Park Drive, Suite 590 

Houston 77036 

Tel: (713) 771-7237 

UTAH 

t'Hamilton/Avnet Electronics 
1585 West 21 00 South 
Salt Lake City, 84119 
Tel: (801) 972-2800 

WASHINGTON 

t'Hamilton/Avnet Electronics 
13407 North rup Way 
Bellevue 9SO05 
Tel: (206) 746-8750 
tAlmac/Stroum Electronics 
5811 Sixth Ave. South 
Seattle 98108 
Tel: (206) 763-2300 
tLiberty Electronics 
1750 132nd Avenue NE 
Bellevue 98005 
Tel: (206) 763-8200 

WISCONSIN 

t'Hamilton/Avnet 
2975 Moorland Road 
New Berlin 53151 
Tel: (414) 784-4510 



CANADA 

ALBERTA 

tl_ A. Varah Ltd. 
4742 14th Street N.E. 
Calgary T2E 6LT 
Tel: (403) 276-8818 
Telex: 13 82589 77 
BRITISH COLUMBIA 
tL.A. Varah Ud. 
2077 Alberta Street 
Vancouver V5Y 1C4 
Tel: (604) 873-3211 
TWX: 610-929-1068 
Telex: 04 53167 

ONTARIO 

L.A. Varah, Ltd. 

505 Kenora Avenue 

Hamilton L8E-3P2 

Tel: (416) 561-9311 

TELEX: 061-8349 

t'Hamilton/Avnet Electronics 

3688 Nashua Drive, Unit GH 

Mississauga L4V IM5 

Tel: (416) 677-7432 

TWX: 610-492-8867 

t'Hamilton/Avnet Electronics 

1735 Courtwood Cresc. 

Ottawa K2C 3J2 

Tel: (613) 226-1700 

TWX: 610 562-1906 

tZentronlcs 

141 Catherine Street 

Ottawa, Ontario K2P 1C3 

Tel: (613) 238-6411 

tZentronlcs 

99 Norflnch Dr. 

Downsview, Ontario M3N 1W8 

Tel: (416)635-2822 

Telex: 02-021694 

QUEBEC 

t'Hamilton/Avnet Electronics 
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St. Laurent H4S1G2 

Tel: (514)331-6443 

TWX: 610-421-3731 



tMIcrocomputei 
•Mlcrocomputei 



System Technical Demonstrator Centers 
System Spares Order Point 



HEXADECIMAL INSTRUCTION CODES 



ACCUMULATOR 



• ADD A,R r 


• ADD A,@R0 


R1 


• ADD A,#data 


• ADDC A,R r 


• ADDC A,@R0 


R1 


• ADDC A,#data 


ANL A,R r 


ANL A,@R0 


R1 


ANL A,#data 


ORL A,R r 


ORL A,@R0 


R1 


ORL A,#data 


XRL A,R r 


XRL A,@R0 


R1 


XRL A,#data 


INC A 


DEC A 


CLR A 


CPL A 


RL A 


• RLC A 


RR A 


• RRC A 


• DA A 


SWAP A 


DATA MOVES 


MOV A,R r 


MOV A,(5)R0 


R1 


MOV A,#data 


MOV R,A r 


MOV @R0,A 


R1,A 


MOV R r ,#data 


MOV @R0,#data 


R1,#data 


XCH A,R r 


XCH A,@R0 


R1 


XCHD A,@R0 


R1 


MOV A.PSW 


• MOV PSW.A 


MOVX A,@R0 


R1 


MOVX @R0,A 


R1.A 


MOVP3 A,@A 


MOVP A,@A 



6* 
60 
61 
03 
7* 
70 
71 
13 
5* 
50 
51 
53 
4* 
40 
41 
43 
D* 
DO 
D1 
D3 
17 
07 
27 
37 
E7 
F7 
77 
67 
57 
47 



F* 

F0 

F1 

23 

A- 

A0 

A1 

B* 

B0 

B1 

2- 

20 

21 

30 

31 

C7 

D7 

80 

81 

90 

91 

E3 

A3 



REGISTER 

INC R r 
DEC R r 
INC @R0 
R1 
DJNZ R r , addr 

FLAGS 

• CLR C 

• CPL C 
CLR F0 
CPL F0 
CLR F1 
CPL F1 

BRANCH 

JMPaddr 
JMPP @A 
DJNZ R r ,addr 
JC addr 
JNC addr 
JZ addr 
JNZaddr 
JT0 addr 
JNT0 addr 
JT1 addr 
JNT1 addr 
JF0 addr 
JF1 addr 
JTFaddr 
JNI addr 
JBO addr 
JB1 addr 
JB2 addr 
JB3 addr 
JB4addr 
JB5 addr 
JB6addr 
JB7 addr 

TIMER 

MOV A,T 
MOV T,A 
STRT T 
STRT CNT 
STOP TCNT 
EN TCNTI 
DIS TCNTI 



1* 
C* 
10 

11 

E* 



97 
A7 
85 
95 
A5 
B5 



t4 
B3 
E* 
F6 
E6 
C6 
96 
36 
26 
56 
46 
B6 
76 
16 
86 
12 
32 
52 
72 
92 
B2 
D2 
F2 



42 
62 
55 
45 
65 
25 
35 



CONTROL 

EN I 
DIS I 

SEL RB0 
SEL RB1 
SEL MBO 
SEL MB1 
ENTO CLK 

SUBROUTINE 

CALL addr 

RET 

RETR 

NO OP 

NOP 

input/output: 

IN A.P1 
OUTL P1,A 
ANL P1,#data 
ORL P1, #data 

IN A, P2 
OUT L P2, A 
ANL P2, #data 
ORL P2,#data 

INS A, BUS 
OUTL BUS, A 
ANL BUS, #data 
ORL BUS, #data 

MOVD A,Pp 
MOVD Pp,A 
ANLD Pp,A 
ORLD Pp,A 



= Carry Flag Affected 
= See Table 1 



: = See Table 2 
t = See Table 3 



TABLE 1. REGISTER ACCUMULATOR. 



Rr 


MOV A,R 


MOV R,A 


XCH A,R 


MOV R, #DATA 


INC R 


DEC R 


DJNZ R 


ADD A,R 


ADDC A,R 


ANLA,R 


ORL A,R 


XRL A,R 


RO 


F8 


A8 


28 


B8 


18 


C8 


E8 


68 


78 


58 


48 


D8 


R1 


F9 


A9 


29 


B9 


19 


C9 


E9 


69 


79 


59 


49 


D9 


R2 


FA 


AA 


2A 


BA 


1A 


CA 


EA 


6A 


7A 


5A 


4A 


DA 


R3 


FB 


AB 


2B 


BB 


1B 


CB 


EB 


6B 


7B 


5B 


4B 


DB 


R4 


FC 


AC 


2C 


BC 


1C 


CC 


EC 


6C 


7C 


5C 


4C 


DC 


R5 


FD 


AD 


2D 


BD 


1D 


CD 


ED 


6D 


7D 


5D 


4D 


DD 


R6 


FE 


AE 


2E 


BE 


1E 


CE 


EE 


6E 


7E 


5E 


4E 


DE 


R7 


FF 


AF 


2F 


BF 


1F 


CF 


EF 


6F 


7F 


5F 


4F 


DF 



TABLE 2. INPUT/OUTPUT. 



Port 


IN 


OUT 


AND 


OR 


BUS 


08 


02 


98 


88 


P1 


09 


39 


99 


89 


P2 


OA 


3A 


9A 


8A 


P4 


0C 


3C 


9C 


8C 


P5 


0D 


3D 


9D 


8D 


P6 


0E 


3E 


9E 


8E 


P7 


OF 


3F 


9F 


8F 



TABLE 3. BRANCH. 



Page 


JMP 


CALL 





04 


14 


1 


24 


34 


2 


44 


54 


3 


64 


74 


4 


84 


94 


5 


A4 


B4 


6 


C4 


D4 


7 


E4 


F4 



Page = 256 bytes 



MCS-48 ,M DATA TRANSFER INSTRUCTIONS 



DATA RAM 




EXTERNAL 
MEMORY 
AND 
PERIPHERALS 



11 



STACK FORMAT 



PROGRAM 
STATUS WORD (PSW) 



HIGH I0DDI 
LOCATION 



PSW PSW 

7 I 1 I 4 


PC11 PC8 

I I I 


PC7 

1 1 1 


PCO 

I I I 



SAVED IN STACK STACK POINTER 



c 


AC 


FO 


BS 


1 


s 2 


Si 


so 



C CARRY 

AC AUXILIARY CARRY 

FO FLAGO 

BS REGISTER BANK SELECT 



intel 
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